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NB! 


Denne manualen beskriver operativsystemet TIKOS for 
16 bit tilleggskortet til Tiki-100 datamaskinen. 
TIKOS er laget som en integrert del av 8-bit oper- 
ativsystemet TIKO for samme maskin. TIKO er beskrevet 
egen manual og forutsettes kjent av alle som skal 
benytte TIKOS. 


TIKOS muliggjør kjøring av 16-bits programmer som er 
laget for CP/M-86 operativsystemet fra firmaet Digital 
Research i USA. 


Manvualen er organisert i følgende kapitler: 


Kapittel 1 inneholder grunnleggende informasjon om 
TIKOS for terminalbrukere. Her beskrives bl.a. 
hvilke filer som må finnes på systemdisketten for 
å kunne kjøre 16-bit  TIKOS programmer. Dette 
kapitlet bør leses grundig av alle som skal bruke 
TIKOS. Kapittel 2 gir en detaljert beskrivelse av 
TIKOS's programfunksjoner, og er beregnet for folk 
som skal utvikle nye programmer under TIKOS på 
maskinkode nivå. 


TIKOS er et norsk system. Alle feilutskrifter er på 

norsk. TIKOS kan også fåes i engelsk versjon. Fordi 

alle TIKOS programmer startes fra (8-bit)  TIKO, 

inneholder 'TIKOS ingen innebygde brukerkommandoer. 

I tillegg til å være en norsk versjon av CP/M-86 
operativsystemet, inneholder TIKOS en rekke 

forbedringer og utvidelser i forhold til standard 

CP/M-86. Av disse kan kort nevnes: 


- Automatisk disk "reset" ved diskett bytte. 
- Største filstørrelse øket fra 8 Mb til 32 Mb. 
= Største platestørrelse øket fra 8 Mb til 512 Mb. 
- Utvidete rettefunksjoner ved linjeinntasting. 
- Flere programfunksjoner. 


Forslag til forbedringer og endringer mottas med takk, 
og kan sendes til 
Tiki-Data A.S, Postboks 108 Refstad, N-0513 Oslo 5 


CP/M-86 er registrert varemerke til Digital Research. 
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TIKOS brukerbeskrivelse. 


l. TIKOS brukerbeskrivelse. 


Hva er TIKOS ? 


TIKOS =- TIKi OperativSystem - er operativsystemet 
for 16 bit tilleggskortet for Tiki-100 datamaskinen. 
Denne datamaskinen har en 8 bit Z80 som hoved- 
prosessor. Tiki-100 er utviklet og produsert i Norge 
av firmaet Tiki-Data A.S. 


TIKOS muliggjør kjøring av 16 bit programmer laget for 
det verdenskjente amerikansk-produserte CP/M-86 
systemet fra Digital Research. 'TIKOS er funksjons- 
messig kompatibelt med CP/M-86 versjon 2.2. I praksis 
betyr dette at ethvert program som kan kjøres på et 
standard CP/M-86 system også vil virke under TIKOS. 
TIKOS inneholder også en del forbedringer og 
utvidelser i forhold til CP/M-86. 


TIKOS er integrert i 8-bit operativsystemet TIKO. 
Kommandotolkeren TKT i TIKO er utvidet til også å 
kunne lete etter 16 bit programmer ved programlasting. 
16 bit TIKOS inneholder derved ingen spesielle bruker- 
kommandoer. Lasting av 16-bit programmer foregår på 


samme måte som lasting av 8 bit programmer. 
Eksempel: 


a>>KAT *.TEK (Laster 8-bit programmet KAT) 


a>>XDIR *.TEK (Laster 16-bit programmet XDIR) 


Under selve kjøringen av 16-bit programmer, virker 
Z80 mikroprosessoren som en slave ELT 8088 
prosessoren. Z80 utfører normalt alle inn/ut 
operasjoner mot periferutstyr (skjerm, skriver, etc.) 
etter kommando fra 8088. 
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1.2 


Le. 


TIKOS systemfiler. 


TIKOS består av følgende filer som må finnes på 
systemplaten (vanligvis disk A) under kjøring: 


l) 8088.COM - 280 slaveprogram. 


2) TIKOS.SYS =- Inneholder selve 16 bit operativ- 
systemet. 


8088.COM filen. 


8088.COM filen inneholder slaveprogrammet på Z80 under 
kjøring av 16 bit programmer. Programmet sørger også 
for å overføre alle nødvendige parametre til 16 bit 
programmet som skal kjøres. Videre vil 8088 programmet 
lese TIKOS.SYS filen inn til 8088 første gang et 16 
bit program kjøres. 


TIKOS.SYS filen. 


TIKOS.SYS filen inneholder selve 16 bit operativ- 
systemet som kjører på 8088 prosessoren. Filen lastes 


normalt kun en gang inn til 8088 første gang et 16 bit 
program skal kjøres. 


Den viktigste delen av TIKOS.SYS filen er 16 bit fil- 
systemet TIFS88 (=Tiki FilSystem for 8088). TIFS88 
inneholder alle nødvendige programfunksjoner for å 
kunne kjøre CP/M-86 programmer. 


Oppstart av TIKOS. 


TIKOS startes opp automatisk av 8088 programmet første 
gang et 16 bit program skal kjøres. Når TIKOS startes, 
vil følgende melding komme på skjermen: 


TIKOS (16 bit) - ver x.yz 


(x.yz = versjonsnummer) 


TIKOS kan også bli lest inn og startet på nytt ved 
følgende situasjoner: 


- et program har "gått i frø" og ødelagt TIKOS 
- etter at SHIFT BRYT er tastet 
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Program kommandoer. 


Som nevnt tidligere er kommandotolkeren TKT i 8 bit 
TIKO utvidet til også å søke etter 16 bit programmer 
ved kommandoinntasting. 16 bit programfiler har etter- 
navn (CMD, mens 8 bit programmer har filtype COM. 
Brukere av TIKOS vil derved ikke merke forskjell på 
om et program er 8 eller 16 bit. Brukeren skriver 
bare programnavn etterfulgt av nødvendige program- 
parametre. 


Eksempel: 


Anta at platen inneholder programfilene KAT.COM 
og XDIR.CMD som begge kan ha et flertydig filnavn 


som parameter. Programmet KAT.COM lastes ved å 
skrive 


a>>KAT *.TIK 


mens programmet XDIR.CMD startes ved å taste 


a>>XDIR *.TIK 


Hvis kommandotolkeren finner en fil på disken med 
etternavn CMD som passer med inntastet kommandonavn, 
blir slaveprogrammet 8088.COM lastet inn i Z80's 
hukommelse. Dette programmet sørger dernest for å 
gi besked til 16 bit TIKOS om at angitt 16 bit program 
skal kjøres. Selve programlastingen blir til slutt 
utført av TIKOS. 


Kommandotolkeren KKT i 8 bit TIKO leter alltid først 
etter 8 bit programmer. Hvis et 8 bit og et 16 bit 
program har samme navn, vil følgelig 8 bit programmet 
bli kjørt. Den eneste måten å få lastet 16 bit 
programmet på er å skrive 8088 etterfulgt av program- 


navn. 


Eksempel: 


Anta programfilene PROG.COM og PROG.CMD finnes på 
platen. Kommandoen 


a>>PROG parameter 
vil laste PROG.COM filen, mens kommandoen 
a>>8088 PROG parameter 


må skrives for å kjøre PROG.CMD programmet. 
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1.4.1 XDIR ffn 


XDIR programmet skriver ut på skjermen en sortert 
filkatalog over alle filene som finnes på platen som 
passer med det flertydige filnavnet ffn. Utskriften 
vil også informere om størrelsen på hver fil, samt 
hvor mye dataplass som er ledig på platen. Programmet 
utfører stort sett det samme som 8 bit programmet KAT. 


Følgende XDIR kommandoer er lovlige: 


XDIR xx * 

XDIR (Samme som XDIR *.*) 
XDIR B:TIKI.* 

A:XDIR *.BA? 


XDIR 24* (Alle filer med fornavn på 
kun EN bokstav) 
XDIR X.Y (Hvor stor er filen X.Y?) 


1.4.2 INTV 


INTV programmet skriver ut innholdet av avbrudds- 
tabellen (="interrupt" vektor) til 8088 prosessoren. 
Programmet kan være nyttig under utvikling av nye 
programmer. 
Eksempel: 

a>>INTV 


Vis 8088 avbrudds-tabell for TIKI-100 16 bit prosessor - ver 1.00 


Avbrudd nr: 0 : 0040:2709 TIKOS - Divisjon med 0 

Avbrudd nr: 1 : 3BF6:090A ? - Prosessor enkelt steg 
Avbrudd nr: 3 3BF6:0902 ? - Innhopp til "debugger" 
Avbrudd nr: 4 


0040:270CE TIKOS - Register overflyt 

0040:27DF TIKOS - IBM-FC spesial funksjon 
0040:29AA 'TIKOS - Les fra Z80 dataport 

0040:29B2 TIKOS - Skriv til 280 dataport 

0040:29BA TIKOS - Utfør Z80 subrutine 

0040:29EF TIKOS - Retumer 280 segment adresse 
0040:29F3 TIKOS - Flytt 8-bit ord til/fra Z80 huk. 
0040:29FC TIKOS - Flytt 16-bit ord til/fra Z80 huk. 
0040:0B06 TIKOS - Funksjons-innhopp adresse 

: 0040:0B06 TIKOS - Funksjons-innhopp fra "debugger" 


Avbrudd nr: 16 
Avbrudd nr: 160 
Avbrudd nr: 161 
Avbrudd nr: 162 
Avbrudd nr: 163 
Avbrudd nr: 164 
Avbrudd nr: 165 
Avbrudd nr: 224 
Avbrudd nr: 225 
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TIKOS feilmeldinger. 


Feil under TIKOS kan enten oppstå under opplast eller 
under kjøring av 16 bit programmer. 


Feil under opplast. 


Følgende feilsituasjoner blir oppdaget under opplast 


av 16 


2) 


3) 


bit programmer: 
8088.COM filen finnes ikke på systemplaten 
TIKOS.SYS filen finnes ikke på systemplaten 


8088 tilleggskort mangler 
Manglende 8088 hukommelse for programmet 


8088.COM filen finnes ikke på systemplaten. 
Hvis brukeren har tastet en 16 bit program- 
kommando og filen 8088.COM ikke finnes på 
systemplaten, vil feilmeldingen 

80882? 
komme opp på skjermen. For å få kjørt 16 bit 
programmet, må brukeren kopiere inn 8088.COM 
filen til systemplaten. 
TIKOS.SYS filen finnes ikke på systemplaten. 
Hvis TIKOS.SYS filen ikke finnes på systemplaten 
ved første gangs kjøring av 16 bit programmer, 
vil feilmeldingen 

Finner ikke TIKOS.SYS filen! 
komme opp på skjermen. Brukeren må da kopiere 
TIKOS.SYS inn på systemplaten. 
8088 tilleggskort mangler. 
TIKOS vil oppdage om 8088 prosessorkortet ikke 
er satt inn i maskinen, eller at kortet ikke 


virker. Feilmeldingen 


8088 prosessor mangler! 


vil bli skrevet ut. 
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4) Manglende 8088 hukommelse for programmet 


TIKOS oppdager hvis programmet krever mer 
hukommelse enn del som finnes på 8088 kortet 
eller at programmet må lastes inn i et område 
som ikke er ledig. TIKOS vil skrive ut følgende 
feilmelding på skjermen: 


Hukommelse mangler 


L+5s2 Feil under kjøring. 


Følgende type feilmeldinger kan komme på skjermen 


under 


1) 
2) 


1) 


kjøring av 16 bit programmer. 


Filsystem feil. 
Avbruddsfeil fra 16 bit prosessor. 


Filsystem feil. 


TIKOS kan oppdage 4 forskjellige feilsituasjoner 
under utførelse av filfunksjoner fra 16 bit 
programmer. Når slike feil oppstår, skriver 
TIKOS ut meldingen 


Feil på <p>: <feilmelding> 


på terminalen, hvor <p> er platelageret dåder 
feilen oppstod, A til P, og <feilmelding> er en 
av disse 4 meldingene: 


Les/skriv 
Gal plate 
Fil KUN lesbar 
KUN lesbar 


"Les/skriv" feilmeldingen betyr at en fysisk 
feil under lesing eller skriving har oppstått på 
platen. Som oftest skyldes dette at disketten er 
ødelagt. Brukeren kommer ut av denne feil- 
situasjonen ved å taste KONTROLL-C eller en 
annen tast. KONTROLL-C stopper det kjørende 
programmet, mens programmet fortsetter hvis en 
annen tast slås. Brukeren kan imidlertid 
risikere at filkatalogen kan ødelegges hvis 
KONTROLL-C ikke tastes ved fysisk feil. Brukeren 
bør derfor være sikker på å ha sikkerhetskopi av 
disketten i slike tilfeller. 
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2) 
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"Gal plate" feilmeldingen oppstår når 16 bit 
program prøver å logge seg inn på en plate som 
ikke finnes. Brukeren kvitterer med å trykke en 


tast. Dette fører til at programmet avbrytes. 


"Fil KUN lesbar" feilen oppstår når et program 
prøver å skrive til en FIL som er skrive- 
beskyttet. Samme feil oppstår om filen blir 
forsøkt fjernet eller endret navn på. Brukeren 
kvitterer på feilmeldingen ved å trykke en tast, 
og programmet avbrytes. 


"KUN lesbar" feilmeldingen skrives ut når et 
program prøver å skrive til en PLATE som er 
skrivebeskyttet. Brukeren kvitterer med å trykke 
en tast, og programmet avbrytes. Normalt vil en 
plate i TIKOS aldri automatisk bli skrive- 
beskyttet. Brukeren kan midlertidig  skrive- 
beskytte en plate ved hjelp av 8 bit programmet 
"SETT". 


Avbruddsfeil fra 16 bit prosessor. 


TIKOS har innebygd mekanisme for å fange opp 
avbruddssituasjoner fra 8088 prosessoren. Slike 
avbrudd skyldes som regel en feil ved det 
kjørende programmet og fører til at programmet 
stoppes. 


Når slike feil oppstår, skriver TIKO ut 
*% <feil> i: SSSS:0000 - Programmet stoppet ** 
hvor <feil> er en av disse 3 meldingene: 


Divisjon med 0 

Register overflyt 

IBM-PC interrupt 10 ulovlig 
Ulovlig interrupt <nn> 


"Divisjon med 0" feilmeldingen betyr at et 
program har prøvd å dividere med 0. 


"Reaister =overflyt" betyr at overflyt har 
oppstått i et av 8088  prosessorens regne- 
registre. For at dette skal skie, må det 
kjørende programmet ha gitt en spesiell 
"kommando" til 8088 (se 8088 manual). Denne 
feilsituasjonen oppstår sjelden. 
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"IBM-PC interrupt 10 ulovlig" feilmeldingen 
oppstår nå en på TIKI-l100 prøver å kjøre 
programmer som er spesiallaget for  IBM-PC. 
Feilsituasjonen oppstår nå programmet utfører 
8088 instruksjonen "INT 10" (10 hex) for å 
utføre en IBM-PC spesialfunksjon. 


"Ulovlig interrupt <nn>" feilmeldingen skyldes 
at det kjørende programmet har forsøkt å utføre 


en 8088 "INT nn" instruksjon, hvor nn er et 
hexadesimal tall. 


Etter at en av de ovenfornevnte avbruddsfeil har 
oppstått, må TIKOS lastes inn på nytt for å 
kjøre flere 16 bit programmer. 
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2. TIKOS program beskrivelse. 


Dette kapitlet omhandler TIKOS's interne organisering 
og alle  TIKOS's programfunksjoner. Meningen med 
innholdet er å gi den nødvendige informasjon til å 
kunne utvikle nye programmer under TIKOS. 


Innholdet forutsetter at leseren er kjent med 8088 
maskinkode-programmering ("assembly"). Brukere av 
høynivåspråk, f.eks BASIC eller PASCAL, vil typisk 
utføre TIKOS funksjoner ved hjelp av spesielle språk- 
konstruksjoner i de enkelte høynivåspråk. Disse vil 
være beskrevet i brukerbeskrivelsene for språkene. 


TIKOS moduler. 


TIKOS er logisk inndelt i seks deler, Tiki Monitor 
Prom (TMP88), Tiki Inn-Ut Modul (TIUM88), TIki 
FilSystem (TIFS88), Tiki Program Laster  (TPL88), 
Kommando og Program Område (KP088), og  Avbrudds- 
Tabellen (AT88). 


TMP88 er det fast innbrente programmet på 8088-"' 
kortet som starter opp når strømmen slås på, den 
såkalte monitorprommen. Modulen inneholder kun et 
lite oppstart program for å kunne kommunisere med 
hovedprosessoren Z80. 


TIUM88 inneholder funksjoner for å kople 'TIKOS'S 
program-funksjoner ELI den elektronikk-nære 
programvaren i Z80 hukommelsen. Modulen inneholder 
bl.a en del disktabeller som kopieres fra Z80's 
TIUM modul før oppstart av alle 16 bit programmer. 


TIFS88 inneholder alle systemfunksjoner som kan 
utføres fra et program. 


TPL88 inneholder funksjoner for å kunne 
kommunisere med 280 prosessoren samt å kunne 
starte opplastingen av 16 bit programmer. 


Kommando Programområdet KPO88$ er den delen av 
hukommelsen der programkommandoer blir lastet inn 
og utført. Størrelsen av KPO88 kan variere noe fra 
forskjellige utgaver av Tiki maskinen. 


Avbruddstabellen AT88 utgjør den nederste 1K av 


8088 hukommelser og inneholder pekere til 8088's 
avbrudds-subrutiner. 
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Figuren nedenfor illustrerer hvordan TIKOS er plassert 
i hukommelsen: 


FFFFFH 
! ! 
! TMP88 ! Monitor Prom 
] | 
EE Er ! 
' es 82080098 1 
! TPO88 ! Programområde 
] ] 
! ! 
! BES re ! Inn/ut modul 
T ! ! TIUM88 ! 
på ! ban oe KE AOE2SOD 
K ! ! ! 
0) ! ! TIFS88 ! Filsystem 
S ! ! er 
. ! fre KE 
5 ! ! ! 
Y ! ! TPL88 ! Programlaster 
S ! ! ! 
! ! ! 40:0 
Ky GT GT 
! AT88 ! Avbrudds-tabell 
! ! 0 


Figur 2-1. 8088 hukommelseskart 


TIKOS.SYS filen inneholder modulene TPL88, TIFS88 og 
TIUM88S. 


2.2 Program fil format 


Alle 8088 programkommandoer er lagret på filer med 
etternavn "CMD". CMD filer består av et 128 tegns 
sektor hode etterfulgt av selve programmet. Sektor- 
hodet består av 8 9-tegns gruppebeskrivelser (GB). 
Hver GB beskriver en del av det programmet som skal 
lastes. Figur 2-2 viser sektorhodet. 


——— -— > --— == -— -—— — 


1 1 1 1 I 1 n 1 1 ! 
! GBL ! GB2 ! GB3 ! GB4 ! GB5 ! GB6 ! GB7 ! GBS ! ! 
! ! ! ! OR ! ! ! ! 

0 9 18 27 36 45 54 63 så LØ 


Figur 2-2. Sektor hode på programfiler 
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På figur 2-2 er GBl til GBS de enkelte xgruppe- 
beskrivelsene. Hvert gruppefelt beskriver en enhet av 
programmet som kan lastes separat, og har et format 
som vist i figur 2-3. 


— —=— -— —— -——— —— — 


å ! ! ! U ! 
! G-TYPE ! G-LENGDE ! A-BASE ! G-MIN ! G-MAX ! 
! ! ! ! ! ! 


N I 3 5 7 8 
Figur 2-3. Gruppebeskrivelse format 


G-TYPE angir gruppe type, og er et 8-bit tall med 
verdi 1 til 8 som vist i tabell 2-1. Tabellen viser 
også de tilsvarende 8088 segment registrene for de 
enkelte gqruppetypene. Segment registrene (untatt SS) 
vil bli satt opp til å peke på starten av de enkelte 
gruppene i hukommelsen når programmet starter. 


Sektorhodet i en kommandofil kan ikke inneholde flere 
gruppebeskrivelser med samme G-TYPE verdi. 


! G-TYPE Gruppe type Segment register ! 
] ==============================================" 
! OLH Kode gruppe CS ! 
! 02H Data gruppe DS ! 
1 038 Ekstra gruppe ES ! 
! 04H Stack gruppe SS Å 
! 05H Ekstra gruppe 1 ss ! 
! .06H Ekstra gruppe 2 ne ! 
!1 07H Ekstra gruppe 3 -- ! 
! 08H Ekstra qruppe 4 ad ! 


Tabell 2-1. Lovlige G-TYPE felt. 


Alle resterende felt i gruppebeskrivelsen er 16-bit 
tall som angir antall 16-byte blokker (1 byte = 1 8- 
bit ord, 16 byte = 1 paragraf). Således beskriver 
gruppefeltene 20-bit verdier med de nederste 4 bit 
satt til 0. Tabell 2-2 beskriver 16-bit feltene i 
gruppebeskrivelsen. 
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Sektorhodet i 16-bit  programfiler definerer den 
såkalte program-modellen programmet skal kjøres etter. 
Program-modeller er beskrevet i avsnitt 2.4. "Z80- 
modell" antas når sektorhodet bare inneholder en kode- 
gruppebeskrivelse. "Liten 8088 modell" antas når både 
kode- og datagruppe er tilstede, men ingen andre 
gruppebeskrivelser finnes. Mer enn to gruppe- 
beskrivelser definerer såkalt "stor 8088 modell". 


og 
(0) 
| 
t 
w 
(0) 
[0] 
= 
K 
|-- 
< 
(0) 
|- 
u 
(00) 


G-LENGDE Angir antall paragrafer (16-byte 
blokker) i gruppen på selve program- 
filen. F.eks betyr en G-LENGDE på 80H 
at gruppen opptar 800H tegn på filen 
(2048 desimalt). 


G-BASE Definerer absolutt paragraf adresse i 
hukommelsen gruppen skal lastes til. 
Normalt vil G-BASE være 0. Operativ- 
systemet vil da laste gruppen inn på 
et ledig område i hukommelsen. 


G-MIN Definerer minimum antall paragrafer 
som trengs til gruppen i hukommelsen. 
Hvis G-MIN er 0, antas G-MIN lik 
G-LENGDE. 


G-MAX Definerer maksimum antall paragrafer 
som gruppen kan bruke i hukommelsen. 


Hvis G-MAX er 0, antas G-MAX lik 
G-MIN. 


Tabell 2-2. 16 bit felt i gruppebeskrivelsen. 


Sektorhodet på programfiler blir automatisk generert 
av diverse 16 bit  utviklings-programmer, f.eks. 
"GENCMD "-programmet fra Digital Research. 
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Program system område. 


Når et 16 bit program lastes inn i hukommelsen, vil 
TIKOS sette opp en del parametre i det såkalte system- 
området til programmet. Systemområdet opptar de første 
100 Hex (256 desimalt) 8-bit ordene av programmets 
data-gruppe (data-segment). Systemområdets innhold er 
vist i figur 2.4. 


0) 1 2 3 4 5 6 
I ======= +------- +------- +------—- +-------= +------- + 
0 ! KODE LENGDE ! KODE BASE ! MZ80 ! 
| -=-======——————=————==—=———————mmmmm mm mm ! 
6 ! DATA LENGDE ! DATA BASE ! Ledig ! 
| — — => — — — — — == —= — — — — == — — — — == == > > > > å > > > > > > > > > > > > > > > > > — €— —— — ! 
OC ! EKSTRA LENGDE ! EKSTRA BASE ! Ledig ! 
| =«=======—=——=—=—=—=—=—=====—===—==e======—======—==—===—== ! 
12 ! STACK LENGDE ! STACK BASE ! Ledig ! 
| =«==-===—=—-=—====—====e=ee—ee—e====e==========—=e====== ! 
18 ! EKSTRALl LENGDE ! EKSTRAl BASE ! Ledig ! 
| = — — — —= v > > av ov > > > > > 3 > > > > > > > > > > an > > > > > > > > > > > > > > > > > > > ! 
lE ! EKSTRA2 LENGDE ! EKSTRA2 BASE ! Ledig ! 
| «======—————————=———=—==———====mmmmmmmmm mm mm mm —— ! 
24 ! EKSTRA3 LENGDE ! EKSTRA3 BASE ! Ledig ! 
| == — > => > > > Om> > > mr > Et OED > > > > > > - > > > > 00 > > Om > > OE> > OED > > > > > > > > > > > > ' 
2A ! EKSTRA4 LENGDE ! EKSTRA4 BASE ! Ledig ! 
| — — — — — — > — — == == == == == 2 å — — — — — — — å —å —å må å => > må > — — — — — — == — — =— — — — — — ! 
! ! 
! Ikke brukt ! 
1 ! 
5C |-----=----—=-—=—=—=—=—=—=—=—=====—======================= ! 
! ! 
! STANDARD FILKONTROLL-BLOCK 1 ! 
! (FKB1) ! 
6C |-----------e==—=—=———=—=—>=—=—=—==========—====—==—======== ! 
! ! 
! STANDARD FILKONTROLL-BLOCK ! 
! (FKB2) ! 
80 !----=--=-----=--============—==========—====———=—====== ! 
! ! 
! KOMMANDOHALE ! 
t ! 
! STANDARD INN/UT BUFFER ! 
' ! 
| 

100 


Figur 2.4. Program systemområde. 


Feltene i program systemområde er definert på neste side: 
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- MZ80 feltet beskriver hvilken program-modell 
programmet har. Feltet kan ha følgende verdier: 


l 
0 


Z80 modell 
ikke Z80 modell (liten/stor 8088 modell) 


Lengde feltene angir lengden i antall 8-bit ord 
av de enkelte gruppene i programmet (kode,data, 
ekstra,stack,ekstral,..ekstra4). Lengde-feltene 
består av 3 8-bit ord der det første ordet utgjør 
de laveste sifrene i tallet. KODE-LENGDEN for 780 
modell programmer er aldri større enn OFFFFH. 


Base feltene angir segment addressen til starten 
i hukommelsen av de respektive gruppene 
programmet. Den fysiske 20 bit adressen framkommer 
ved å multiplisere segment adressen med 16. 


- De to standard filkontroll-blokkene settes opp av 
TIKOS på de faste adressene 5CH og 6CH i system- 
området. Formatet på filkontrollblokker (FKB) er 


beskrevet i avsnitt 2.8. Når en kommandolinie 
på formen 


PROGRAM "filnavnl" "filnavn2" - 


tastes, lages den første FKBen i adresse 5C Hex 
med filnavn feltene fylt inn med "filnavnl". Den 
andre FKBen blir laget i en del av den første 
FKBen (adresse 6C Hex), og inneholder "filnavn2". 
Denne FKBen må flyttes til en annen del av 
programhukommelsen før den kan brukes, mens den 
første kan brukes der den er. Uspesifiserte tegn i 
"filnavnl" og "filnavn2" blir fylt med blanke i de 
tilsvarende FKBene. Små bokstaver i filnavnene 
blir oversatt til store. 


Kommandohalen er en kopi av den delen av kommando- 
linjen som er etter selve programnavnet. Kommando- 
halen fylles inn i systemområdet fra adresse 81 
Hex, med lengden på kommandolhalen fylt inn i 
hukommelses-cellen i adresse 80 Hex. Alle små 
bokstaver blir også her oversatt til store. 
Eksempelvis vil kommandolinjen 


a>>XDIR Z80.CPU Norsk 
resultere i følgende innhold fra adresse 80H: 


DE 20 5A 38 30 2E 43 50 55 20 4E 4F 52 53 4B 
GB GERNE NG £ 8 


Kommandohale-området fra adresse 80 Hex brukes 


også som standard buffer for fil inn/ut 
operasjoner. 
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Program modeller. 


Når et 16 bit program blir lastet inn i hukommelsen, 
vil segment-registrenes (CS,DS,ES,SS) startverdier 
bestemmes av hvilken modell programmet kjører under. 
Programmodellen er angitt i sektorhodet i CMD filen 
for programmet. Tre program modeller finnes, Z80 
modell, liten 8088 modell, og stor 8088 modell. 
Tabell 2-3 sammenfatter de tre modellene. 


! Z80 modell Kode- og datagruppe overlapper 
! 
! Liten 8088 modell Separat kode- og datagruppe 
] 
1 
] 


Stor 8088 modell Mer enn to separate grupper 


Tabell 2-3. Program modeller. 


Under alle programmodellene vil TIKOS sette opp et 
internt stack-område på 96. hukommelses-celler som 
programmet kan benytte. Figur 2.5 viser det interne 
stack området i TIKOS. 


(SS = Stack Segment) 
= Stack Peker) 


Ne) 
N 
n 
D 
| 
|-- 
M 
KB 


Figur 2.5. Internt TIKOS stack-område 


Første element i den interne stacken vil inneholde en 
returadresse EE TIKOS slik at programmet kan 
returnere til TIKOS ved å utføre en "RETF"- 
("RETurn Far") instruksjon. 
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"Assembler" språk eksempel: 


TIKOS EQU 224 ; TIKOS interrupt 

; 
CSEG * Z80 PROGRAM MODELL 
ORG 100H 

START: 
MOV CL,1 : LES ET TEGN FRA 
INT TIKOS : TASTATURET 
ik ; (Mer programkode) 
RETF SLUTT PÅ PROGRAM 


we "eo 


RETURNER TIL TIKOS 


Z80 modell. 


Z80 modellen brukes av programmer som er direkte 
oversatt fra 8 bit 8080 eller Z80 programmer. 780 
modellen består av kun en program gruppe som 
inneholder både kode, data og stack-områder. 8088's 
segment registre blir ved oppstart satt til å peke på 
starten av gruppen. Gruppens lengde er begrenset til 
64K. Programeksemplet ovenfor viser et Z80 modell 


program. Figur 2.6 illustrerer modellen. 
| =«===e—=——=—==== ! 
! ! 
1 KODE/DATA ! 
! e 0800 8 ! 
LE leøre ! 
! ! 
! KODE/DATA ! 
CS:IP -----= > 100H I!---=======-== ! (IP=Instruction 
! System- ! Pointer) 
! område ! 


Figur 2.6. Z80 modell 
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2.4.2 Liten 8088 modell. 


Programmer som kjører under denne modellen består av 
en uavhenging kode gruppe og data gruppe. Kode- og 
datagruppen er som regel, men behøver ikke være, 
begrenset i størrelse til 64K. Figur 2.7 illustrerer 
liten 8088 programmodell. 


! ! 

! ! 

fann aesssenme ! ! DATA ! 
! ! ! ! 
! KODE ! ! ae ! 
! ! ! ! 
! He G-o ! ! ! 
! ! ! DATA ! 
I ! 100H |--=--=------—-= ! 
! KODE ! ! System- I 
! ! ! område ! 
ESP ->-5 0: 1>ao5s>eese=== ! DS,ES ===> 0 |---====-e-—=e ! 


Figur 2.7. Liten 8088 modell. 


Programeksemplet nedenfor viser et assembler program 
skrevet i liten 8088 modell: 


TIKOS EQU 224 : TIKOS interrupt 

; 
CSEG s LITEN 8088 MODELL 
ORG 0 

START: 
MOV VAR, 0 : NULLSTILL VARIABEL 
MOV DX, OFFSET FKB 
MOV CL,15 : ÅPNE FIL 
INT TIKOS 


(Mer programkode) 


* 

* 

* 
-e 


DSEG ; DEFINER DATAOMRÅDE 
ORG 5CH ; STANDARD FKB 

FKB RB 36 
ORG 100H 

VAR DB 0) ; VARIABEL 


END 
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2.4.3 


Stor 8088 modell. 


Programmer skrevet for denne programmodellen har en 
eller flere uavhengige programgrupper i tillegg til 
kode- og datagruppe. Som regel vil de ekstra gruppene 
være ekstra- og/eller stack-segment gruppe. Programmet 
vil i slike tilfeller som regel selv være i stand til 
å manipulere 8088's interne segment-registre. Figur 


2.8 viser en typisk stor 8088 modell konfigurasjon 
etter programopplast. 


. ! 

! ! ! 
! ! ! DATA ! foensesnee> ! 
! KODE ! ! ! ! I 
! I ! 604» ! ! DATA ! 
! aå ! ! ! I ! 
i ! ! DATA ! ! era ! 
! ! 1008. fr-————— ! ! 2 
! KODE 2 ! System- ! 2 DATA å 
! ! DS: ! område ! ES: ! ! 
Jeep ! — Dg fo--ssne-me ! sr GJ I 


Figur 2.8. Stor 8088 modell. 


22 
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System-kall konvensjoner. 


TIKOS systemfunksjoner tilgjengelig fra bruker- 
programmer faller i fire klasser, enkle tegn inn-ut 
funksjoner, filsystem funksjoner, hukommelses- 
funksjoner og TIUM-funksioner. 


Følgende type tegn inn-ut funksjoner finnes: 


Les et tegn fra tastaturet 

Test om nytt tegn er klart fra tastaturet 
Les en linje fra tastaturet 

Skriv et tegn på videoskjermen 

Les et tegn fra port (serieport P2) 

Skriv et tegn til port (serieport P2) 
Skriv en sekvens av tegn på videoskjermen 
Skriv et tegn på tilkoplet skriver 
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Følqende type filfunksjoner finnes: 


Initier filsystemet 

Velg ut et bestemt platelaqer 

Laq fil 

Åpne fil 

Lukk fil 

Søk i filkatalogqen 

Fjern fil 

Endre filnavn 

Les sekvensielt eller randomisert fra fil 
Skriv sekvensielt eller randomisert til fil 
Finn ut hvilke platelagre som er logget inn 
Finn ut hvilken plate som er utvalgt 


Sett lese/skrive adressen i hukommelsen (DMA) 
Sett fil-attributt 


Sett filsystem feil modus 
Utfør et (annet) program 
Last inn program 


Følgende type hukommelses funksjoner finnes: 


Bestem maksimal hukommelse tilgjengelig 
Tildel hukommelse 


Frigi hukommelse 
TIUM88 basis inn/ut funksjoner: 


Alle TIUM88 inn/ut funksjoner kan brukes fra 


brukerprogram. Normalt vil bare teqn-funksjoner 
brukes. 
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TIKOS proqgramfunksijoner utføres ved hjelp av 8088 
programinstruksjonen INT 224. Ved funksjonsinnhopp 
inneholder maskinregister CL alltid et  funksjons- 
nummer. Parametre til funksjonen overføres i  DX- 
registeret eller bare DL (DX=DH*256+DL). Parametre 
vil enten være et tall, f.eks et skjermtegn som skal 
skrives ut; eller en peker (adresse) til en 
hukommelseslokasjon som igjen kan inneholde flere 
parametre. For  pekerparametre vil alltid segment- 
registeret DS brukes som segment base. 


TIKOS funksjonene vil returnere til bruker- 
programmet med 8 bits returparametre i AL-registeret, 
og 16 bits returparametre i AX-registerparet. Dessuten 
vil alltid BX registeret være lik AX. I tillegg vil 
som regel segmentregister ES være satt til segmentet 
der selve TIKOS ligger (= 40 Hex). 


Programeksempel: 


CSEG s LITEN 8088 MODELL 
ORG 0 
JMP START 
p 
OPSYS: INT 224 : TIKOS INNHOPP 
RET 
START: 
s DS:DX = FKB PEKER 
MOV DX, OFFSET FKB 
MOV £5, 15 ; ÅPNE FIL 
CALL OPSYS 
CMP AL, OFFH ; SJEKK OM FIL FUNNET 
JZ NOT FOUND 
E : FIL FUNNET 
EE : (Mer programkode) 
NOTFOUND: : FIL IKKE FUNNET 
MOV CL,0 ; AVSLUTT PROGRAM 
MOV DL,0 
JMP OPSYS 
DSEG ; DEFINER DATAOMRÅDE 
ORG 5CH : STANDARD FKB 
FKB RB 36 
ORG 100H 


(Data område) 


=o 


Tabell 2-4 viser alle TIKOS programfunksioner med 
tilhørende funksjonsnumre. 


25 


TIKOS programbeskrivelse. 


0 - Last opp TIKO 30 - Sett filattributt 

l - Tastatur inn 31 - Hent platetabell 

2 - Skierm ut adresse 

3 = Port inn 32 - Sett/hent bruker nr. 
4 — Port ut 33 - Les vilkårlig sektor 
5 - Skriver ut 34 —- Skriv vilkårliq sektor 
6 - Direkte terminal 35 - Beregn fil størrelse 

inn/ut 36 - Beregn random sektor 

7 - Hent INN/UT celle 37 - Logg ut plater 

8 - Sett INN/UT celle 40 - Skriv vilkårlig sektor 
9 - Skriv tegnsekvens med NULL-stilling 

10 - Les tastatur linje 45 - Sett filsystem feil- 
ll - Tastatur status modus 
12 - Versjonsnummer 47 - Start opp et annet 

13 - Initier filsystemet : program 

14 - Velgut plate 50 - Utfør TIUM88 funksjon 
15 - Åpne fil 51 - Sett lese/skrive inn/ 
16 - Lukk fil ut buffer segment 
17 - Søk etter første 52 - Returner lese/skrive 
18 - Søk etter neste inn/ut adresse 

19 - Fjern fil 53 - Angi maksimal til- 
20 - Les sekvensielt gjengelig hukommelse 
21 - Skriv sekvensielt 54 - Angi maksimal til- 


22 - Lag fil 


gjengelig hukommelse 
23 - Endre filnavn 


fra oppgitt base 


24 - Hent innloggingstabell 55 - Alloker hukommelse 
25 - Hent utvalqt plate 56 - Alloker hukommelse fra 
26 - Sett lese/skrive inn/ en bestemt base 

ut (offset) adresse 57 - Frigi hukommelse 
27 - Hent BLOKKTABELL adr. 58 - Frigi all hukommelse 
28 - Skrivebeskytt plate 59 - Programlast 
29 - Hent plater som er 

skrivebeskyttet 


Tabell 2-4. TIKOS programfunksjoner. 


26 


TIKOS programbeskrivelse. 


Fil-type. 


Etternavnet på en fil brukes ofte til å angi hva slags 
TYPE fil dette er, mens fornavnet brukes til å navngi 
de enkelte filene av denne filtypen. Tabellen nedenfor 
viser de fleste "standard" filtyper. 


ASM - Assembly kildetekst 

PRN - Listbar på skriver 

HEX - Hexadesimal maskin kode 

BAS - BASIC kildetekst 

PAS - PASCAL kildetekst 

COM - 8 bit programfiler 

BAK - Kildetekst sikkerhetskopi 

SYM - Symbol fil (brukt til programtesting) 
BBB - BASIC programmer 


C - C kildetekst 
CMD - 16 bit proaramfiler 
SUB - "BATCH" fil 


A86 - 16 bit assembler kildetekst 
HB86 - 16 bit HEX-format filer 
$S$ - Midlertidig fil 


Fil-format. 


Filer i TIKOS kan generelt ses på som en sekvens av 
opp til 262144 logiske TIKOS sektorer, hver på 128 
8-bits tegn. Fildata vil alltid leses og skrives i 
faste blokker på en sektor. Sektorene er nummerert fra 
0 til 262143, og tillater lagret over 32 millioner 
tegn pr. fil (et TIKOS platelager kan være på 
maksimalt Gå. 530 millioner teqn). De logiske 
sektorene vil for TIKOS proqrammer se ut som om de er 
lagret sammenhengende på platelageret, men fysisk kan 
de være spredt på platelageret i usammenhengende 
områder. TIKOS's interne filorganisering er 
uinteressant for de aller fleste TIKOS programmer. 


Filer vil normalt inneholde data laaret på enten tegn- 
format ("ASCII") eller binært-format. Eksempel på 
tegnfiler er kildetekstfiler, mens programmer alltid 
vil være lagret på binærfiler. 
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Tegnfiler er å betrakte som en lang sekvens av 7-bits 
ASCII-tegn organisert i linjer. Hver linje er en 
vilkårlig lang tegnsekvens etterfulgt av spesial- 
tegnene CR ("Carriage Return" =- tegnkode 13) og LF 
("Line Feed" - tegnkode 10). Linjebredden vil normalt 
være fra 0 til ca. 130 tegn. En TIKOS sektor kan 
inneholde flere linjer, og en linje kan også strekke 
seg over flere (normalt maksimum 2) sektorer. Slutten 
på en tegnfil angis ved et slutt-på-fil spesialtegn 
(KONTROLL-Z - tallkode 26). Hvis siste tegn i filen 


faller på en sektorgrense, kan slutt-på-fil tegnet 
utelates. 


Binærfiler består av et antall sektorer inneholdende 
binære 8 bits tall. Alle 8-bits tall, 0-255, kan 
lagres. Binære filer vil typisk være program- eller 
rådata-filer. Slutt-på-filen angis ved en sektorteller 
i filkatalogen og vil alltid falle på en sektorgrense. 
Programmer som leser binærfiler, må alltid sjekke på 
slutt-på-fil status fra TIKOS under lesingen. 


Fil-kontrollblokk. 


De fleste TIKOS filsystemfunksjonene trenger en peker 
til en filkontrollblokk (FKB) som funksjonsparameter i 
8088's DX registerpar ved systeminnhopp. En FKB er en 
sammenhengende rekke av 36 8-bits tegn ("bytes") 
plassert i hukommelsem. Figur 2.9 viser FKB formatet. 
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sn mo on on On 0 0 3 om am «=> am Om am OD 3 OD 3 €3 G2 Om OG €2> GM am Ax Om MED GE GE GE GE3 GUD Mm> AND OD GED CD GP > ED > GE OD > OED OED 0 OED OED + 
IplIf1l1f21 .. 1£81tlit2!t3!smislis2!sti1bOo! ...!bnils!rO!rl!r2! 

spd ati ht oe GJ ee i + 
00 01 02 08 09 10 11 12 13 14 15 16 31 32 34 34 35 


De enkelte felter i FKB'en er definert som følger: 
pl = plate lager (0-16) 


0 -> bruk innlogget plate for fil 
l -> bruk plate A for filoperasjon 
2 -> bruk plate B for filoperasjon 


16 -> bruk plate P for filoperasjon 


f1-f8 - fil fornavn på opptil 8 tegn. 
Hvert tegn er et 7-bits ASCII tegn (bits 
0-6). Bit 7 i hvert tegn er 0. Kun store 
bokstaver bør brukes. Filnavnet avsluttes 
med et antall blanke tegn for filnavn med 
lengde mindre enn 8. 


tl-t3 ”- fil etternavn (type) på opptil 3 tegn. 
Hvert tegn er et 7-bits ASCII tegn (bits 
0-6). tl: og +2' ør bit 7 av tl og t2, og 
er filattributter. 


1/0 -> Skrivebeskyttet/les og skriv 


tl' = 
t2' = 1/0 -> Systemfil/Normal fil 
sm = segment teller. 


Teller for TIKO's 16K segmenter. Normalt 
satt til 0 av brukerprogrammer, men kan 
variere fra 0 til 31 under filoperajoner. 


sl - reservert for internt bruk. 

s2 - reservert for internt bruk. 
Programmer bør sette s2 til 0 før fil- 
funksjonene ÅPNE,LUKK og SØK. 

st - sektor teller innen hvert segment, 0-127. 


b0-b1l5 Reservert for internt bruk. 


ls og løpende sektor. 
Teller logisk sektor under sekvensielle 
filoperasjoner. Vanligvis satt til 0. 


r0-r2 logisk sektor nummer, 0 - 262143 
Brukes kun under filoperasjoner som leser 
eller skriver vilkårlige sektorer. r0, rl 


or r2 utgjør et 18-bits sektornummer. 


Figur 2.9 Fil-kontrollblokk (FKB). 


29 


TIKOS programbeskrivelse. 


2.9 


Programfunksjoner. 


Denne delen beskriver alle 'TIKOS programfunksjoner 
samt funksjonsparametrene brukerprogrammer må overføre 
når de kaller de enkelte funksjonene. Funksjonsnumre 
og funksjonsparametre er angitt som hexadesimale tall. 
Hexadesimale tall skrives med bokstaven "H" bak 
tallet. 


I beskrivelsen av de enkelte filfunksjonene er 
betegnelsene "offset adresse" og "segment adresse" 
mye brukt. "Offset adresse" (OA) er en 16 bit adresse 
relativt til starten av et hukommelses-segment. 
"Segment adresse" (SA) bestemmer startadressen til 
segmentet, og er et 16 bit tall som representer en 
fysisk 20 bit adresse med de nederste 4 bit satt til 
0. "Virkelig" fysisk adresse (VA) framkommer således 
ved følgende formel: 


VA = (SA*16) + OA 


Figur 2.10 illustrerer sammenhengen mellom offset-, 
segment-, og virkelig adresse. 


OA !..Data objekt.. O 
F 
F (OA) 
(Segment S 
adresse, SA) E 
T 
SA * 16. ----> 0 !------=-=---====== ! 


Fysisk adresse til data objekt: (SA*16) + OA 


Figur 2-10. Segment/offset adresse. 


30 


TIKOS programbeskrivelse. 


*Kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Funksjon 0: Avslutt program -* 
* * 
kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 
* * 
kg Avslutter et TIKOS program. % 
* * 
*KkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkkKKK 
* V * 
* Inngangsparametre: N 
* * 
” Register CL: 00H å 
* Register DL: 0 eller 1 ig 
* * 
* Utgangsverdier: * 
* * 
% Ingen * 
* * 
k*kkekkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkeKkk KKK 


Denne funksjonen brukes Eri å avslutte TIKOS 
programmer. Hvis DL-registeret er satt til 1 ved 
innhopp, vil hukommelsen som okkuperes av programmet 
ikke bli frigitt. Ellers frigis hukommelsen som opptas 
av programmet. 
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kkkkkkkkkkkKkkKkKKKKKKKKRKKKKKKKKKKKKKKKKKKKKK KER KK 


* * 
* Funksjon l: Tastatur inn - 
* * 
kkkkkkkkkkkkkkkkkkKKKKKKRKRKKKKKKKKKKK KKK KKK KERK K 
* * 
* Les et tegn fra tastaturet. ” 
* * 
kkkkkkkkkkkkkkkkkKKKKKKkKRkRKKKKKKKKKkKkKRKKKkEKKKKRKKK 
* * 
* Inngangsparametre: * 
* * 
% Register CL: O1H å 
* * 
* Utgangsverdier: * 
* * 
* Register AL: Inntastet tegn (ASCII) » 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkKKRKKkkKRKKRKKKKKRKTKK KKK 


Tastatur-inn funksjonen leser neste tegn fra 
tastaturet til AL-registeret. Funksjonen venter til 
brukeren har tastet et tegn. Funksjonen gir også ekko 
av grafiske tegn ut på vwvideoskjermen. Som grafiske 
tegn regnes bokstaver, tall, spesialtegnene, samt 
kontroll-tegnene CR, LF og Kontoll-H (flytter 
skrivemerket EN posisjon til venstre).  Tabulator 
tegnet (Kontroll I) flytter skrivemerket til neste 
tabulator posisjon. Funksjonen tester også på spesial- 
tegnet kontroll-S som starter og stopper skjerm 
utskrift, samt kontroll-P som starter og stopper 
ekko til skriveren. 
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kkkkkkekkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Funksjon 2: Skjerm ut ” 
* * 
kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 
* * 
* Skriv et tegn på videoskjermen * 
* * 


*KkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkK 
* 


* 


Inngangsparametre: 


Register CL: 02H 
Register DL: Tegn (ASCII) 


Utgangsverdier: 


* 
* 
* 
* 
* 
* 
* 
Ingen % 
* 
* 


* 
* 
* 
* 
* 
* 
* 
* 
* 
* 


kkkktekkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKk 


Skjerm-ut funksjonen skriver tegnet i DL-registeret ut 
på  videoskjermen. Tabulatortegn (kontroll-I) blir 
ekspandert til blanke, og funksjonen tester også på 
inntastet start/stopp skjerm tegn (kontroll-S) og 
skriver ekko tegn (kontroll-P). 
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KkkkkkkkkkkkkkkkkkkkkKkkRkkkkkKkkkkKKkkREKKRKRERKK 


* * 
* Funksjon 3: Port inn * 
* * 
kkkkkkekkkkkkkkRekKRkRTKKRTKRKKKKkKkTKReKKKKKRKKKKKKKKKKK 
* * 
* Les et tegn fra port (kanal P2) % 
* 


* 
KkkkkkkkkkkkkkkKKKKRkKkKKeRkKRKKKKRKRKKRKKKKKKKKRRRRK KKK 


* * 
* Inngangsparametre: % 
* * 
* Register CL: 03H ” 
* * 
* Utgangsverdier: ; 
* * 
* Register AL: Tegn fra port (ASCII) % 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkRkkkKkkkkKRKKKKRKKRKKRR 


Port-inn leser neste tegn fra port P2 på Tiki 
datamaskinen til AL-registeret. Funksjonen venter til 
neste tegn er klar på porten. Denne funksjonen 
tilsvarer TIUM88 funksjonen PAPBÅNDI, som leser et 
tegn fra papirbånd. Papirbånd brukes imidlertid ikke 
lenger. Istedenfor leser funksjonen fra seriekanal P2. 
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kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkrkkkkkkK 


* * 
* Funksjon 4: Port ut 2 
* * 
kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 
* * 
* Skriv et tegn til port (P2) Re 
* i * 
kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkakkkkkkkkkkkkk kerk 
* * 
* Inngangsparametre: * 
* * 
* Register CL: 04H * 
* Register DL: Tegn (ASCII) * 
* * 
* Utgangsverdier: * 
* * 
” Ingen * 
* * 
*kkkkekkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKKKK 


Skjerm-ut funksjonen skriver tegnet i DL-registeret ut 
på port P2 på Tiki datamaskinen. Denne funksjonen 
tilsvarer TIUM88 funksjonen PAPBÅNDU, som skriver et 
tegn til papirbånd. Papirbånd brukes imidlertid ikke 
lenger. Istedenfor skriver funksjonen til seriekanal 
P2,. 
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akk kkkkkkkKkKKkTKKKKTRKKRKKKKKKKKKKKKKTKKKK KIKK KRRK 


* * 
* Funksjon 5: Skriver ut * 
* * 
**ækkkkkkkkkeKkkkKTKkTKKkK KERK KKKkkekRKKTKKKKRKTKRKKKKKKK 
* * 
2 Skriv et tegn på tilkoplet skriver å 
* * 
*kkkkkkkkkkkkkkkkkkKkKKkKKRkKTKKRkKKKRkKKKKTKKKKKKKKKKK 
* * 
* Inngangsparametre: å 
* * 
* Register CL: 05H å 
% Register DL: Tegn (ASCII) * 
* * 
* Utgangsverdier: * 
* * 
* Ingen * 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkKKRKKRKKKRKKK 


Skriver-ut funksjonen skriver tegnet i DL-registeret 
ut på tilkoplet skriver. Brukeren må selv sørge for at 
skriveren er slått på. 
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kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 
* * 


* Funksjon 6: Direkte terminal inn/ut * 
*x * 


kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


*+ 


Skriv et tegn på videoskijermen, 
test om tegn er klart fra tastaturet, 
les tegn fra tastaturet. 


k*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkRKKK 


Innqangsparametre: 


Register CL: 06H 

Reqister DL: OFFH hvis tastatur status/inn 
Register DL: OFEH hvis tastatur status 
Register DL: OFDH hvis tastatur inn 
Register DL: Tegn hvis skierm ut 


Utganasverdier: 

Tastatur status/inn: 
= OH hvis tastaturteqn ikke klart 
= inntastet tegn hvis tegn klart 

Tastatur status: 

Register AL: 

= OH hvis tastaturteqn ikke klart 
= OQOFFH hvis tastaturtean klart 


Tastatur inn: 


Register AL: 
= inntastet tegn 


Skjerm ut: 


* 

* * 
* * 
* * 
* * 
* * 
& * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* A * 
* Register AL: å 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* Ingen * 
* * 
* * 


kkk*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkkKKKKKKK 


Direkte-terminal-inn/ut funksjonen brukes av 
programmer som ikke ønsker noen form for behandling 
av terminal inn/ut data. Ingen testing på spesial- 
funksjonene start/stopp skierm (kontroll-S), ekko til 
skriver (kontroll-P) eller tabulator (kontroll-I) blir 
utført. Denne funksionen er forøvrig noe utvidet i 
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forhold til standard CP/M-86. 


Programmer kaller direkte-terminal-inn/ut funksjonen 
med å sette DL-registeret til en av fire verdier. 
Verdien i DL-registeret blir brukt til å bestemme hva 
slags inn/ut funksjon som skal utføres. Følgende 
verdier settes i DL-registeret ved innhopp: 


OFFH 


Funksjonen tester om brukeren har trykket 
en tast. Hvis ikke, returneres verdien 0H 
i AL-registeret. Hvis en tast er trykket, 
returneres tegnet i AL. 


OFEH 


Funksjonen tester bare om brukeren har 
trykket en tast. Hvis ikke, returneres 0H 
i AL-registeret. Hvis brukeren har slått en 
tast, returneres OFFH i AL. 


OFDH 


Funksjonen leser neste tegn fra tastaturet. 
Funksjonen venter til et tegn er trykket. 
Tegnet returneres i AL-registeret. 


Tegn Hvis E-registeret verken er OFFH, OFEH 
eller OFDH ved innhopp, tolkes DL- 
registeret som et tegn som skal skrives ut 
på videoskjermen. Ingen returparametre blir 
returnert i dette tilfellet. 
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*kkkkkkkkkkkkkKkKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkrk 


* * 
* Funksjon 7: Hent INN/UT celle - 
* * 
*KkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 
* * 
* Hent TIKOS INN/UT celle fra Z80 hukommelse * 
% Brukes til redirigering av terminal inn/ut * 
* * 
*kkkkkkkkkkkkkkkKkkRKKkRkkkkkkkkkkkkkkkkkkkkkkkK KKK 
* * 


* Inngangsparametre: 
* 


* 
* 
* Register CL: 07H * 
* * 
* Utgangsverdier: * 
* * 
* Register AL: INN/UT celle * 
* * 
* * 


kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKK 


Hent-INN/UT-celle funksjonen henter fram aktuell 
verdi av systemets INN/UT celle som er lagret i Z80's 
hukommelse. Cellen blir brukt til å kunne dirigere 
terminal INN/UT enten til innebygget tastatur og 
tilkoplet  videoskjerm eller til  spesial-tilkoplet 
terminal over serielinje. Følgende bit i INN/UT cellen 
brukes: 


BIt De 0 -> Tastatur INN.tas fra innebygget 
tastatur. 
l -> Tastatur INN tas fra terminal 
tilkoplet over serielinje. 


Bit Le 0 -> Standard videoskjerm brukes for 
skjerm UT funksjoner. 
l -> Skjerm UT tegn sendes til tilkoplet 
terminal over serielinje. 


Bit 2-7: Ikke brukt, men reservert. 
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kKkækkkkkkkkkkkkkKKKKKKKKRKKKKRKKKkKKKKKKKKKKKKKKKKK 


* * 
* Funksjon 8: Sett INN/UT celle * 
* * 
kkkkkkkkkkkkkkkkKKkkKTkKKKKKKKKKKKKRKKKKKKKRKKKKRKKKK 
* * 
* Sett TIKOS INN/UT celle i Z80 hukommelsen. * 
* Brukes til redirigering av terminal inn/ut * 
* * 


køkkkkkkkkkkkKkkkkKKkkRKKkkeReKKKKKKKK KKK kKKKKKKKKKRK 
* 


Inngangsparametre: 


* 
* * 
* * 
* Register CL: 08H * 
* Register DL: INN/UT celle * 
* * 
* Utgangsverdier: * 
* * 
* Ingen i 
* * 
* * 


*kkkkkkkkkkkkkkkkkkkekkkkkkkkKkEkKkKkKKRKKKKKKKRK 


Sett-INN/UT-celle funksjonen setter ny verdi inn i 
systemets INN/UT celle lagret i %Z80 hukommelsen. 
Cellen blir brukt til å kunne dirigere terminal INN/UT 
enten til innebygget tastatur og tilkoplet videoskjerm 
eller til spesialtilkoplet terminal over serielinje. 
Følgende bit i INN/UT cellen brukes: 


Bit 0: 0 -> Tastatur INN tas fra innebygget 
tastatur. 
l -> Tastatur INN tas fra terminal 
tilkoplet over serielinje. 


BLE 13 0 -> Standard videoskjerm brukes for 
skjerm UT funksjoner. 
l -> Skjerm UT tegn sendes til tilkoplet 
terminal over serielinje. 


Bit 2-7: Ikke brukt, men reservert. 
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*kkkkkkkkkkkekkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Funksjon 9: Skriv tegnsekvens * 
* * 
*KkkkkkkkkkkkkkkkkkkKkKkKKkkKKKkkKKKKkKKkKkkkKkKkkKKK 
* * 
Skriv en sekvens av tegn på skjermen * 
* * 
kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 
* * 
* Inngangsparametre: % 
* * 
* Register CL: 09H ” 
se Register DX: Tegnsekvens offset adresse å 
* Register DS: Tegnsekvens segment adresse * 
* * 
* Utgangsverdier: * 
* * 
% Ingen % 
* . * 
*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkkkkkkkkkkkKKKK 


Skriv-tegnsekvens funksjonen skriver en tegnsekvens 
lagret i hukommelsesadressen gitt i DX-registeret til 
skjermen. Et '"$"-tegn brukes til å avslutte tegn- 
sekvensen. Tabulatortegn blir ekspandert til blanke, 
og spesialfunskjonene start/stopp skjerm (kontroll-S 
tastet) og skriver ekko (kontroll-P tastet) blir 
utført. 
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*kkkkkkekkkkkKkRKKRKKKTKKKKKTKKKKKKKKKRKKRTKKKKKK ERIK K 


* * 
* Funksjon 10: Les tastatur linje * 
* * 
kkkkkkkkkkkkkkkkkkkkkKKKKRKKKKRKKKTeKKRKKeKKTKKkRKKRKK 
* * 
he Les en inntastet linje fra tastaturet ko 
* * 
KkkkkkkkkkKKKKkkRkKKKTkKKKKKKKKKKKKeKKKKkkkeKK KK KKK 
* * 
* Innqangsparametre: å 
* * 
* Register CL: OQAH N 
* Register DX: Linjebuffer offset adresse * 
* Register DS: Linjebuffer seqment adresse * 
* * 
* Utqangsverdier: * 
* * 
” Linjebuffer fylt med tegn på 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkekkkkkkkkKK 


Les-tastatur-linie funksjonen brukes til å lese en 
linje fra tastaturet. Linjen avsluttes når enten 
linjebufferet er fullt eller når CR- eller LF tasten 
trykkes. Liniebufferet har følgende format: 


DX: +0 +1 +2 +3 +4 


hvor "ml" er maksimal lengde på linjebufferen, "at" er 
antall inntastete tegn og "tl",.."tn" er de enkelte 
tegnene på linjen. Brukerproqrammer må alltid sette 
bufferlengden "ml" før funksionen kalles. Hvis "at" er 
mindre enn "ml", vil resten av bufferet inneholde det 
samme som sto der ved funksionsinnhopp. 


Under åinntastingen finnes de samme spesial/rette- 
funksjonene som brukeren har  tilgienaelig under 
vanlig kommandoinntasting (se 8 bit TIKO manual). 


Når funksjonen avsluttes med CR-tasten, vil skrive- 
merket på skjermen flytte seg til samme kolonne- 
posisjon det hadde da funksijonen ble kalt (ikke 
nødvendigvis helt til venstre). 
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kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Funksjon 11: Tastatur status % 
* * 
*KkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkK 
* * 
* Test om nytt teaqn er klart fra tastaturet * 
* * 
*kkkkkekkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkRRKK 
* * 
* Inngangsparametre: på 
* * 
* Register CL: OBH å 
* * 
* Utgangsverdier: * 
* * 
* Register AL: O0FFH hvis tean er klart * 
* OH hvis tegn ikke er klart * 
* * 
* * 


kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkktkkk 


Tastatur-status funksjonen undersøker om brukeren har 
trykket en tast på tastaturet. Hvis et nytt tegn er 
klart, returneres O0FFH i AL-registeret. Hvis ikke, 
returneres 0 i AL. Funksionen bør ikke brukes sammen 
med funksjon nr. 6 (direkte terminal inn/ut). 
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KkkkkkkkkkkkkkkkkkKkKKKKKKKKRKKRKKKKKKKKKKKRKRKKKKKKKK 


* * 
* Funksion 12: Versjonsnummer N 
* * 
KkkkkkkkkkkkkkkkkKKRkKKkkKeKkKkKkkKKKKKKRKKRKKKRKTKKK 
* * 
* Returner TIKOS versionsnummer o 
* 4 * 
*KkkkkkkkkkkkkkkkkkkkkkkKkKkKKKKKKKRKKKKKKKKKKKKRKKRK 
*. * 
* Innqanasparametre: he 
* * 
* Reaister CL: NCH ; 
* * 
* Utaanasverdier: å 
* * 
* Register AX: Versjonsnummer N 
* ; * 
i *kkkkkkkkkkkkkkkkkkkkkKKkkkKKKRKRKKKKKKKRRKKKKRKKKKRK 


Funksjon 12 returnerer versjonsnummer i henhold til 
standard CP/M-86. Versjonsnummer er 0022 Hex. 


Funksjonen brukes av en del standard CP/M-86 
programmer som også kan kjøres under bl.a MP/M-86 
og CCP/M (flerbrukerutgaver av CP/M-86). 


44 


TIKOS programbeskrivelse. 


kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkekkkkKK 


* * 
* Funksjon 13: Initier filsystemet. % 
* * 
*KkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKK 
* * 
* Start opp filsystemet på nytt % 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkkkkkKKkkkkkkkkkkKKK 
* * 
* Inngangsparametre: * 
* * 
å Register CL: ODH ” 
* * 
* Utgangsverdier: * 
* * 
2 Register AL: OFFH hvis fil $*.* fil * 
å finnes på plate A N 
* Register AL: 0 ellers * 
* * 
KkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 


Funksjon 13 brukes av programmer til å sette fil- 
systemet til en tilstand der alle platelagrene kan 
leses og skrives, bare plate A er logget inn og 
standard lese- og skriveadresse for filsystemet er 80 
Hex i programmets systemområde. I  TIKOS behøver 
funksjonen ikke brukes under bytting av disketter, 
fordi TIKOS har innebygd automatisk mekanisme for å 
finne ut om disketter har vært byttet. 


Funksjonen returnerer O0FFH i AL-registeret hvis fil 


med fornavn som begynner med $ finnes på A plate- 
lageret. Ellers returneres 0 i AL. 
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*kekkkkkkkkkkkkkTkkkKKKkkkKKKKKKTKKKKkKRKKTKKKRK KK KKK 


* * 
* Funksjon 14: Velg ut plate g 
* * 
*kkkkkkkkkkkkkkkkKkkeRKKKTRKKKKKREKkkkRkK KKK KKK KKKKK 
* * 
* Velg ut et bestemt TIKOS platelager ” 
* * 


KkkkkkkkkRkKKKKRkkKKkKKKTRKERKKKRKRKRKKKKKKKKKKKKKKK RK KK 
* * 


Inngangsparametre: 


Register CL: OEH 
Register DL: Platelager, 0-15 


Utgangsverdier: 


* 
* 
* 
* 
* 
* 
* 
* Ingen 
* 

* 


* 
* 
* 
* 
* 
* 
* 
* 
* 
* 


kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKTKKKKRRKK 


Velgut-plate funksjonen logger inn platelageret gitt 
av DL-registeret som STÅENDE plate. DL=0 tilsvarer 
plate A, DL=1 angir plate B, helt opp til DL=15 som 
velger ut plate P. Den utvalgte platen vil i 
etterfølgende filsystem-kall aksesseres av 
filfunksjoner der "pl" feltet i filkontrollblokken 
(FKB) er 0. "pl" verdier mellom 1 og 16 vil imidlertid 


ignorere den stående platen og direkte aksessere plate 
A til P. 


Hvis disketter byttes mens de er logget inn, vil TIKOS 
automatisk oppdage dette, og logge inn platen på nytt. 
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*k*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkK 


* * 
* Funksjon 15: Åpne fil % 
* å * 
kKk*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 
* *x 
* Åpne en fil for etterfølgende filfunksjoner * 
* * 
*KkkkkkkkkkkkkkkkkkkkkkkRkKkKkKkKkKkRKkRkKTKKKKKRKKRKKKK 
* * 


* Inngangsparametre: 
* 


Register CL: OFH 
Register DE: FKB offset adresse 
Register DS: FKB segment adresse 


Utgangsverdier: 


Register AL: 0-3 hvis filen ble åpnet. OK 


* 
* 
* 
* 
* 
* 
* 
* 
* 
OFFH hvis filen ikke finnes N 
* 
* 


* 
* 
* 
* 
* 
* 
* 
* 
* 
KkkkkkkekkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkRK* 


Åpne-fil funksjonen forbereder en fil for etter- 
følgende les- og skrivoperasjoner. Filsystemet søker 
etter filen i katalogen under aktiv bruker på det 
angitte platelageret. Feltene i posisjon 1 til 14 i 
filkontrollblokken (FKB) må stemme overens med filen i 
katalogen for at filen skal finnes. Et spørsmålstegn i 
en feltposisjon i FKBen samsvarer med ethvert tegn på 
tilsvarende posisjon i katalogen. Vanligvis vil 
programmer kun spesifisere entydige filnavn i et 
åpne-fil kall. Likeledes vil "sm" og "s2" feltene (se 
avsnitt 2.5) vanligvis settes til 0 før funksjon 15 
kalles. 


Hvis filen finnes på platen, blir kataloginformasjon 
kopiert til feltene "b0" til "bn" i FKBen, slik at 
FKBen kan brukes i etterfølgende lese og skrive 
operasjoner (Merk: Ingen filer kan brukes før de er 
åpnet). 


Funksjon 15 returnerer med AL-registeret satt til 
verdi 0 til 3 hvis filen ble korrekt åpnet. Hvis filen 
ikke finnes returneres OFFH til AL. 


Hvis FKBen inneholder spørsmålstegn, blir den første 
filen i katalogen som passer åpnet. 


Programmer som skal lese og skrive sekvensielt fra den 


første logiske filsektoren, må sette sektor-telleren 
"]s" i FKBen til 0 etter at funksjon 15 er brukt. 


47 


TIKOS programbeskrivelse. 


kkkækkkkkkkkekkkkRKKKkKkkKKKKKKKKKKKKRKKKKK KKK KKKK 


* * 


* Funksjon 16: Lukk fil * 
* * 
kkkkkkkkkkkkkkkkKkkKKKKKKKKkKKKKRkKRKKKRKKKKKKKKKKKKKK 
* : * 
* Lukk en fil etter utførte filoperasjoner N 
* * 


kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkRKkkKkKKKKKKKRKKKKKRK 
* * 


Inngangsparametre: 


Register CL: 10H 
Register DX: FKB offset adresse 
Register DS: FKB segment adresse 


Register AL: 0-3 hvis filen ble lukket OK 


* 
* 
* 
* 
* 
* 
* 
* 
* 
* OFFH hvis filen ikke finnes 
* 

* 


* 
* 

* 

* 

* 

*. 

Utgangsverdier: * 
* 

* 

* 

* 

* 


kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKKKK 


Lukk-fil funksjonen utfører det motsatte av en åpne- 
fil funksjon. Hvis DX-registeret adresserer en FKB som 
tidligere ble brukt til å åpne eller lage en fil (se 
funksjon 15 og 22), vil lukk-fil funksjonen sørge for 


å kopiere all nødvendig fil-informasjon fra FKBen til 
filkatalogen. 


Lukk-fil funksjonen bruker samme søkemekanisme i fil- 
katalogen som åpne-fil funksjonen. 


Funksjon 16 returnerer med AL-registeret satt til 
verdien 0 til 3 hvis filen finnes i katalogen og har 
blitt tidligere åpnet. Hvis filen ikke finnes i 
katalogen, returneres O0FFH i AL. 


Filer som bare leses behøver ikke lukkes etter at de 
har vært brukt (det er imidlertid god skikk å gjøre 
det). Filer som har vært skrevet må imidlertid alltid 
lukkes etter bruk for at filkatalogen skal oppdateres 
med nødvendig informasjon. Hvis ikke, vil det som er 
skrevet mistes. 
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TIKOS programbeskrivelse. 


*kkkkkkkkkkKkkkKKKKkkKkKKkkkkkkkkkkkkkkkkkkkkkKKKKK 


* * 
* Funksjon 17: Søk etter første * 
* * 
kKkkkkkkkkækkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 
* . * 
- Søk etter første forekomst av en fil * 
* * 
*KeækkkkkkkkkkkkRkKKKKKKKkKkKKkKkKKkkkkKkkKkkkkkkkkRk KKK K 
* * 
* Inngangsparametre: * 
* * 
P Register CL: 11H * 
% Register DE: FKB offset adresse * 
R Register DS: FKB segment adresse * 
* * 
* Utgangsverdier: N 
* * 
på Register AL: 0-3 hvis en fil funnet * 
* OFFH hvis ingen fil finnes * 
* * 
* * 


*KkkkkkkkkkkkkkkkKkKkKKeKKKKkkkkKKKkkeKKkKKKKKKKKK 


Søk-etter-første funksjonen søker etter første fore- 
komst av en fil i katalogen på en plate under aktivt 
brukernummer. Verdien OFFH (255 desimalt) returneres 
hvis ingen fil finnes. Ellers vil AL-registeret 
inneholde KATALOG-KODEN 0,1,2 eller 3. Hvis en fil 
samsvarende med FKBen finnes, vil hukommelsen gitt ved 
filsystemets løpende lese/skrive buffer inneholde den 
TIKOS filkatalog sektoren (128 tegn) som inneholder 
den søkte filen. Hvert filelement tar 32 tegn i 
katalogsektoren, og samsvarer med elementene i FKBen. 
- Adressen til det søkte katalogelementet vil kunne 
beregnes ut fra følgende formel: 


adresse = lese/skrive buffer + 32*katalog-kode 


Brukerprogrammer kan undersøke filkatalogelementene 
særskilt, for derved å kunne bestemme f.eks filnavn, 
filtype og størrelse. 


Spørsmålstegn i posisjon 1 (filnavn tegn nr. 1) til og 
med 12 (segment teller) i. FKBen passer med et hvilket 
som helst tegn på samme sted i katalogelementet på 
innlogget plate eller særskilt spesifisert plate. Hvis 
"pl" (plate lager) feltet i FKBen også inneholder et 
spørsmålstegn, vil ethvert katalogelement, ledig eller 
opptatt, tilhørende et hvilket som helst brukernummer, 
på innlogget plate passe. Funksjon 17 vil derved kunne 
brukes til å starte gjennomlesing av fysisk alle 
katalogelementene. Hvis "pl" feltet ikke inneholder 
spørsmålstegn, vil "s2" feltet alltid bli satt til 0. 
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TIKOS programbeskrivelse. 


kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkkKKKKKKKKKKKKRKK 
* * 
* Funksjon 18: Søk etter neste * 
* - * 
kkkkkkkkkkkkkkkkKkKKkKKkKRKKkkRkkkKkKKkKkkRRRKKKKKRKK 


*x' * 
* Søk etter neste forekomst av en fil * 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkeRkKKKkkRkKKKKKKKKKKKKKKK 
* ; * 
* Inngangsparametre: * 
* * 
* Register CL: 12H * 
* * 
* Utgangsverdier: . 
* å * 
* Register AL: 0-3 hvis en fil funnet * 
* OFFH hvis ingen fil finnes * 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkKkRkKKkKKkKKKKKKKKKKKKKK 


Søk-etter-neste funksjonen er lik funksjon 17 bortsett 
fra at gjennomsøkingen i filkatalogen starter fra det 
siste elementet som passet med spesifisert FKB i søk- 
etter-første funksjonen. Funksjon 18 returnerer 
katalog kode i AL-registeret som i funksjon 17. 


Funksjon 18 må etterfølge enten funksjon 17 eller et 
annet funksjon 18 kall. Ingen andre filsystemkall, 


unntatt skjerm- og skriver-kall, må komme imellom to 
søkekall. 
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TIKOS programbeskrivelse. 


kk*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 


* * 
* Funksjon 19: Fjern Fil * 
* * 
Rkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkekkk*K 
* * 
* Fjern en fil fra platen % 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKK 
* * 


Inngangsparametre: 


Register CL: 13H 
Register DX: FKB offset adresse 
Register DS: FKB segment adresse 


Register AL: 0-3 hvis fil(er) fjernet 


* 
* 
* 
* 
* 
* 
* 
* 
* 
OFFH hvis ingen fil finnes * 
* 
* 


* 
* 
* 
* 
* 
* 
* Utgangsverdier: 
* 
* 
* 
* 
* 


kkkkkkkkkkkkkkKkkkkkkkkkkkkkkkkkkkkkkkkkkKKkKRKK 


Fjern-fil funksjonen fjerner filer som passer med 
spesifisert FKB. Angitt filnavn kan være flertydig 
for å kunne fjerne flere filer på en gang. Platelager 
feltet ("pl") i FKBen kan ikke inneholde spørsmåls- 
tegn. 


Funksjon 19 returnerer med O0FFH (255 desimalt) i AL- 
registeret hvis ingen fil som samsvarer med FKBen 
finnes i katalogen. Ellers returneres katalogkoden 
0,1,2 eller 3 i AL. 
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TIKOS programbeskrivelse. 


*kakkkkkkkTKKKTKKKKKRKTKKTTKKRKKRKKTRKKKKERK KERK KKK TIK 
* * 
* Funksjon 20: Les sekvensielt 
* * 
*kkkkkekKTKTeKKkKTTKTRKKTKKKKKKKKTEKKKKKRTKKKKIEK KK KR KKK 
* * 
* Les neste filsektor * 
* * 
*kkkkkkkkkkkkkkkKkKkTTKKTKKKRKKKKKKKTRKKKKKKKKKKKKKRKKK 

* 
Inngangsparametre: 


Register CL: 14H 
Register DX: FKB offset adresse 
Register DS: FKB segment adresse 


Register AL = 0 hvis sektor lest OK 


* 
* 
* 
* 
* 
* 
* 
* 
x 
* 
* <> 0 hvis slutt på filen 
* 

* 


* 
* 

* 

* 

* 

* 

Utgangsverdier: ig * 
* 

* 

* 

* 

* 


kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkkkekkKKKKKKKKRKKKK 


Les-sekvensielt funksjonen leser neste logiske fil- 
sektor fra filen til systemets lese/skrive buffer. 
Spesifisert FKB må tidligere blitt aktivisert ved et 
åpne-fil kall eller et lag-fil kall (funksjon 15 og 
22). Sektoren som leses er gitt ved den løpende sektor 
telleren, "ls", og filsegment telleren "sm" i FKBen. 
Ved lesing økes "ls" til neste sektorposisjon i det 
stående filsegmentet. Funksjonen øker også segment 
telleren til neste filsegment hvis den siste sektoren 
i et segment leses. Programmer som skal lese en fil 
sekvensielt trenger derfor bare sette "ls" feltet til 
0 i FKBen etter at filen er åpnet. 


Funksjon 20 returnerer verdien 0 i AL-registeret hvis 
en sektor ble lest korrekt po Å filsystemets 
lese/skrive buffer i hukommelsen. Hvis ingen flere 
sektorer finnes på filen (dvs. slutt på filen), 
returneres et tall forskjellig fra 0 i AL. 
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TIKOS programbeskrivelse. 


kkakkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Fonksjøon 21: Skriv sekvensielt * 
* * 
*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 
* * 
* Skriv neste filsektor Ne 
* * 
Kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 
* * 
* Inngangsparametre: * 
* * 
* Register CL: 15H * 
å Register DX: FKB offset adresse * 
* Register DS: FKB segment adresse % 
* * 
* Utgangsverdier: * 
* * 
* Register AL = 0 hvis sektor skrevet OK * 
så : <> 0 hvis platen er full * 
* * 
kkæekekkekkKkkkkKKKkkRkKK KKK kkKkkKkkkkkKkkkkKKkKKKKK 


Les-sekvensielt funksjonen skriver neste logiske fil- 
sektor til filen fra systemets lese/skrive buffer. 
Spesifisert FKB må tidligere blitt aktivisert ved et 
åpne-fil kall eller et lag-fil kall (funksjon 15 og 
22). Sektoren som skrives er gitt ved den løpende 
sektor telleren, "ls", og filsegment telleren "sm" i 
FKBen. Ved skriving økes "ls" til neste sektorposisjon 
i det stående filsegmentet. Funksjonen øker også 
segment telleren til neste filsegment hvis den siste 
sektoren i et segment skrives. Programmer som skal 
skrive en fil sekvensielt trenger derfor bare sette 
"]s" feltet til 0 i FKBen etter at filen er åpnet. 


Skriveoperasjoner kan finne sted på eksisterende 
filer. Gamle filsektorer blir da bare overskrevet. 


Funksjon 20 returnerer verdien 0 i AL-registeret hvis 
sektoren ble korrekt skrevet fra filsystemets 
lese/skrive buffer i hukommelsen. Hvis platelageret er. 
fullt, returneres et tall forskjellig fra 0 i AL. 
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TIKOS proqrambeskrivelse. 


*kkkkkkkkkk Ke kkKKKKKKKTKKKKKKRKKKRKKKKKKKREKKKKKRKKKK 
* * 
* Funksjon 22: Lag fil * 
* * 
k*kærkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKRkKKKKKKKKKKRKKKK 
* 
Laq en ny fil * 
* 
*kakkkkkkkkkkkkkkkkkkkkRkKKKK KKK KKKKKKKKKKKKKRKKKKK 
* 

Inngangsparametre: 


Register CL: 16H 
Reaister DX: FKB adresse 
Register DS: FKB adresse 


Reqister AL = 0,1,2,3 hvis filen laaet 
OFFH hvis full katalog 


EE EE GE JG JG. 205. 205 2 Sr 


* 
* 

* 

* 

* 

* 

Utgangsverdier: på 
* 

* 

* 

* 

* 


kkkkkkkkkkkkkkkkkkKkkkkkkKKKkKKkKkkKkKKKKKRKKKKKKKK 


Lag-fil funksjonen virker på samme måte som åpne-fil 
funksjonen, bortsett fra at filen som er spesifisert i 
FKBen ikke må finnes fra før på det aktuelle 
platelageret under stående brukernummer. Filsystemet 
lager et nytt element i katalogen for den angitte 
filen. Brukerprogrammet må selv passe på at filen ikke 
finnes fra før, ellers blir filen duplisert i 
katalogen. Dette kan giøres ved å utføre et fiern-fil 
kall (funksjon 19) foran lag-fil kallet. 


Ved uthopp inneholder AL-registeret verdiene 0,1,2 
eller 3 hvis filen ble korrekt laget. Hvis fil- 


katalogen er full, returneres OFFH (255 desimalt) i 
AL. 


Lag-fil kallet har den sideeffekt at den tilhørende 
FKBen blir fyllt med nødvendig kataloginformasjon 
for etterfølgende lese- og skriveoperasjoner. En på- 
følgende åpne-fil funksjon er derfor ikke nødvendig. 
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TTKOS programbeskrivelse. 


*kkkkkkkkkkkkkkkkkkKkkRkkkkkkkkkkkkkkkkkkkkkkkkkkKK 


* * 
* Funksion 23: Endre filnavn % 
* * 
*KkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkK 
* * 
* Bytt navn på en fil 4 
* * 
KkkkækkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKKK 
* * 
* Inngangsparametre: å 
* * 
* Register CL: 17H % 
* Register DX: FKB adresse * 
* Register DS: FKB adresse ” 
* * 
* Utgangsverdier: % 
* * 
* Reqister AL = 0,1,2,3 hvis navn endret * 
på OFFH filen ikke finnes * 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 


Endre-filnavn funksjonen endrer alle forekomstene i 
katalogen på spesifisert platelager av filnavnet 
angitt i de første 12 posisjonene (felt "pl" til og 
med felt "t3") i FKBen til filnavnet lagret i posisjon 
16-27 (felt "40" til "dll") i samme FKB. Platelager 
feltet å FKBen ("pl") brukes til å velge ut 
platelager, mens '"pl"-koden for den nye FLLHSVDEN: 
posisjon 16 i FKBen, forutsettes å være 0. 


Ved uthopp inneholder AL-registeret verdiene 0,1,2 


eller 3 hvis filnavnet ble korrekt endret. Hvis filen 
ikke finnes, returneres O0FFH (255 desimalt) i AL. 
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TIKOS programbeskrivelse. 


Krakk kkkkkkkkKK KKK KKKKRKKKTKKKKKRKK KKK KKKKRKeRIRKKRKK 


* * 
* Funksjon 24: Hent innloggingstabell * 
* * 


kkkkkkkkkkkkkkk KKK KRKKKKKKRKKKKKKKRKKkKTeKKKKKKRKRKK 
* * 
* Hent bit-tabell over plater som er logget inn * 


* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkRkKRKTKRKKKKRKKKKKKKRK 
* * 
* Inngangsparametre: - 
* * 
* Register CL: 18H - 
* * 
* Utgangsverdier: å 
* * 
* Reqister AX = åinnloggingstabell hå 
* * 
*kkkkkkkkkekKKkkkKKKkKkkkkkkkKkKkKKKKKKKKKKKKKKKKK 


Funksjon 24 returnerer TIKOS 16-bit tabell over 
hvilke platelagre som er logget inn. Bit-tabellen 
returneres i AX-registeret, der bit 0 tilsvarer plate 
A, mens bit 15 tilsvarer plate P. En l-er i en bit- 


posisjon angir at platen er logget inn, mens 0 betyr 
det motsatte. 
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TIKOS programbeskrivelse. 


kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkK 


* Å * 
* Funksjon 25: Hent utvalgt plate % 
* * 
*K*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkekkkkkkkkkkK 
* * 
N Returner stående innlogget plate * 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 
* * 
* Inngangsparametre: i 
* ; * 
* Register CL: 19H R 
* * * 
* Utgangsverdier: - 
* * 
” Register AL = stående plate (0-15) * 
* * 
kk*ækkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 


Funksjon 25 returnerer stående platelager i AL- 
registeret. Platelagre angis ved et tall fra 0 til 
15, der 0 tilsvarer plate A, mens 15 er plate P. 


Funksjonen blir brukt av programmer som endrer plate- 


lager, og som etter kjøring ønsker å vende tilbake til 
opprinnelig stående plate. 
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TIKOS program beskrivelse. 


*kkkkkkkkkKkkkKkkKK KK KKK KeKTKKRRK KK KKK KKKKKKKKRK 
* * 


* Funksjon 26: Sett lese/skrive adresse * 
* * 
kkkkkkkkkkekkkkkkkkkkekKTKKKReKKKKKKKKKKKKKKKKKKKKKK 
* * 
* Sett filsystemets lese/skrive-buffer * 
* offset adresse. * 


* * 


*kkkkkkkkkkkkkkkKKRKRKKKKRKKKKkKkKKTKKKKKKKeRKKKKK KKK 


* * 
* Inngangsparametre: å 
* * 
* Register CL: lAH . 
* Reqister DX: Lese/skrive strast adresse * 
* * 
* Utqangsverdier: * 
* * 
* Ingen * 
* v * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkKKKKKKKKKKKeKKKKKKKRKK 


Funksjon 26 brukes til å sette filsystemets lese/ 
skrive-buffer adresse. Lese/skrive-bufferet er det 
128-tegns området i hukommelsen som brukes til mellom- 
lagrinq av data som skal overføres til og fra filer på 
platelagrene. Bufferet vil inneholde en filsektor 
FORAN skriveoperasjoner og ETTER lesekall. 


Når TIKOS laste opp et program, vil lese- og 
skrivebufferet alltid være satt til adresse 80H i 
proqrammets systemhukommelse. 
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TIKOS program beskrivelse. 


kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkrk 


* * 
* Funksjon 27: Hent BLOKKTABELL adresse å 
* ; * 
*kkkkkkkkkkkkkkkKKkkkKkkkKkkKkkkkkkkkkkkkkkkkkkkKkK 
* * 
N Returner adressen til bit-tabell over * 
% ledige og opptatte blokker for stående å 
» platelager % 
* * 
*KköækkkkekkkKkRkKKKRKKKKTKKKKKKKKKkkkkKKkKkKkkkkkkkKKRRK 
* * 
* Inngangsparametre: * 
* * 
P Register CL; 1BH * 
* * 
* Utgangsverdier: å 
* * 
* Register BX: Blokktabell offset adresse * 
(AX=BX) * 
* Register ES: Blokktabell segment adresse ** 
* * 
kKkkkkkkkkkkkkkkkkkkkkRKkkKKkkkkkkkKkkkkkkkkkkKKKRRK 


TIKOS har en tabell i hukommelsen for hvert platelager 
som angir hvilke blokker på platelageret som er 
optatte og ledige. Tabellen er bit-orientert, dvs. 
hver blokk på. platen er representert ved ett bit i 
tabellen. Funksjonen returnerer tabell-adressen for 
stående plate i ES:BX registerparet. 


Funksjonen kan brukes av  spesial-programmer som 
trenger å vite hvor mye ledig plass som er igjen på 
platelageret. Vanlige programmer trenger ikke bruke 
funksjonen. 


Blokktabellen er forøvrig beskrevet mer i avsnittet 
om INN/UT modulen TIUM88. 
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TIKOS program beskrivelse. 


*kkkkkkkkkkkkkKKKkKKKKKKKKkKRkKKKKRKRKKKRKKKRKKKKKKRKKKK 


* * 
* Funksjon 28: Skrivebeskytt plate Å 
* * 
k*akkkkkkkkkKKKKKKKKKKKKKkKKTKKKKKKKKKRKKKKERKKKKK KKK 
* * 
* Beskytt stående plate mot skriving. * 
* * 
Kkkkk*kkkkkkkkkkkKTkKTKTKKKKKKKKKRKKKKKKKKKKTKKKRKKK KIRK 
* * 
* Inngangsparametre: % 
* * 
* Register CL: 1CH * 
* * 
* Utgangsverdier: . 
* * 
” Ingen * 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKRKKKKKKKRKKKK 


Skrivebeskytt-plate funksjonen beskytter stående plate 
mot etterfølgende  skriveoperasjoner. Hvis senere 
skriveoperasjoner forsøkes, vil filsystemet skrive ut 
feilmeldingen 

Feil på <p>: KUN lesbar 
hvor <p> ér platelager, A-P. 


Funksjonen brukes lite i TIKOS. 
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TIKOS program beskrivelse. 


kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Funksjon 29: Hent skrivebeskyttete plater - 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 
* * 
- Returner bit-tabell over plater som er - 
* skrivebeskyttet * 
* * 
kkkeækkkkkkkkkkkkkkkkkkkkkkkKkkKkkkkkkkkkkkkkKkkKK KKK 
* : * 
* Inngangsparametre: i 
* * 
* Register CL: 1DH 2 
* * 
* Utgangsverdier: * 
* * 
* Register AX: Bit-tabell. * 
* * 
*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKK 


Funksjon 29 returnerer en 16-bit tabell over skrive- 
beskyttete  platelagre. Tabellen returneres i AX 
registeret, der bit 0 tilsvarer plate A, mens bit 15 
tilsvaret plate P. En l-er i en bitposisjon angir at 
platen er skrivebeskyttet, mens 0 betyr det motsatte. 
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TIKOS program beskrivelse. 


kkkkkkkkkkkkkkekKRkRKKKKKKKKKKKRKKKTKKKKKKKKRTKKKKKRKKK 


* * 


* Funksjon 30: Sett filattributt % 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkKKKkRKKKKKKKKKRKKRKKKKKK 
* 
* 
* 


* 

Sett attributt(er) på en fil å 
* 
kkkkkkkkkkkkkkkkkekkkkKkkKKKkKeKKKKKKRKKRKKKKKRKKKKKK 


* 
Inngangsparametre: 


Register CL: lEH 
Register DX: FKB offset adresse 
Register DS: FKB segment adresse 


Utgangsverdier: 


Register AL: 0,1,2,3 hvis attributter 
korrekt satt 


* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* 
* OFFH hvis filen ikke finnes 
* " 

* 


+ GNR 


KkkkkkkkkkkkkkkkkkRKkKkKKKKKkRkKkkkkkKkRkIKKKKKRKKKRK 


Funksjon 30 merker en angitt fil med visse attributter 
(egenskaper). Attributtene angis som det øverste 
bit'et (bit 7) i filnavn-posisjonene ("fl".."f£8","tl", 
"t2","t3") å FKBen. Register AL vil ved uthopp 
inneholde verdiene 0,1,2 eller 3 hvis attributtene ble 
korrekt lagret på tilsvarende posisjoner i katalogen. 


Hvis spesifisert fil ikke finnes, returneres OFFH (255 
desimalt) i AL. 


De mest brukte er lese/skrive- og systemattributtet. 
Lese/skrive attributtet lagres som øverste bit i "tl" 
posisjonen i filkatalogen og brukes til å skrive- 
beskytte filer. Filer med systemfil attributtet påsatt 
(lagret som bit 7 i "t2"), vil ikke bli vist på 
skjermen av kommandotolkerens katalog kommando. 


Brukerprogrammer kan definere andre filattributter i 
FKB posisjonen "fl" til og med "f4". .En vlss 
forsiktighet bør dog utvises, fordi disse attributter 


kan brukes til spesielle formål i framtidige TIKOS 
versjoner. 
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TIKOS program beskrivelse. 


*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Funksjon 31: Hent platetabell adresse * 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkRRKK 
* * 
* Returner adressen til platelager tabellen " 
P for stående plate % 
* * 
*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKK 
* * 
* Inngangsparametre: $ 
* * 
” Register CL: 1FH * 
* * 
* Utgangsverdier: * 
* * 
* Register BX: Tabell offset adresse * 
* (AX=BX) * 
å Register ES: Tabell offset adresse * 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKKKKK 


TIKOS har en tabell i hukommelsen for hvert platelager 
som beskriver platens størrelse og fysiske utforming. 
Funksjon 31 returnerer tabell-adressen for stående 
plate i ES:BX registerparet. 


Funksjonen kan brukes av programmer som trenger 
informasjon om platens fysiske egenskaper. Vanlige 
programmer trenger ikke bruke denne funksjonen. 


Plate-tabellen er lagret i  TIKOSS  INN/UT modul 


(TIUM88), og er dokumentert i  modulbeskrivelsen 
(avsnitt 2.11). 
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kKkkkkkkkkkkkkkkkkkkkkKKkRkTkKKKKKKKKKKKRKK KKK KKKRIRKKK 


* * 


* Funksjon 32: Sett/hent bruker nr. * 
* * 
*kkækkkkkkkkkkkkKkTKKTKTeKTKRKKREKKKTKKKKKKKKKKKKKKKKKER 
* * 
* Sett nytt bruker nummer eller * 
* hent stående bruker nummer * 


* * 


kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKKTRKKRKKKKKKKRKKTKKKK 
* * 


Inngangsparametre: 
Register CL: 20H 


Register DL: OFFH hvis hent bruker 
Register DL: brukernr. hvis sett bruker 


Utgangsverdier: 


Register AL: Stående bruker nummer 
Sett bruker nummer: 


* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* Hent bruker nummer: ' % 
* * 
*x *x 
* * 
* * 
* * 
* Ingen N 
* * 
* * 


kKkk*ækkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkkKKKkReKKKKKKK 


Funksjon 32 kan brukes til enten å forandre stående 
brukernummer eller å få tak i stående brukernummer. 
Hvis register DL er O0FFH (255 desimalt) ved innhopp, 
returneres stående brukernummer i AL-registeret. Hvis 
register DL ikke er 255H, brukes verdien i DL til å 
sette nytt brukernummer (0-15). 
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kKkkkkkkkkkkkkkKkkkkKKKkKkkRKKkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Funksjon 33: Les vilkårlig sektor: * 
* * 
KkkkkkktkkkkkkkkkkkkkkkKKKKkKkKkKKKKkKKKkkkkKKKKKKRKK 
* * 
å Les vilkårlig sektor fra fil * 
* * 
*KkkkkkkkkkkKkkKKKkkkkkkKKkKkkKKKkkkkkKkkkKkKkkKKKKKKK 
* * 
* Inngangsparametre: * 
* * 
” Register CL: 21H å 
.- Register DX: FKB offset adresse * 
å Register DS: FKB segment adresse ” 
* * 
* Utgangsverdier: GE 
* * 
% Register AL = 0 hvis sektor lest OK * 
” <> 0 hvis sektor ikke finnes * 
* * 
*kkkkkkkkkkkkkkkkkkkkkkkKKKKkKKkkkkkkekkkkkKKeRKKKKKK 


Les-vilkårlig-sektor funksjonen virker på samme måte 
som les-sekvensielt funksjonen (funksjon 20) bortsett 
fra at leseoperasjonen kan finne sted på en 
spesifisert vilkårlig sektor-posisjon på filen. 
Posisjonen angis som et 18-bits tall i "r0", "rl" og 
"r2" feltene i FKBen, der "r0" representerer den 
laveste delen av sektortallet. "r2" feltet av FKBen må 
ikke være større enn 3. 


Feltene "rO0","r1" og "rå" kan inneholde en 18 bits 
sektorposisjon fra 0 til 262143. Enhver sektor på 
en maksimalt stor fil på over 33 millioner (33554432) 
tegn kan derved leses. Funksjonen øker ikke sektor 
telleren "ls" i FKBen med 1 slik les-sekvensielt 
funksjonen gjør. Påfølgende kall på funksjon 33 vil 
derfor lese samme sektoren. 


Funksjonen beregner og setter alle FKB tellerne ("sm", 
"st" og "ls") ved hvert kall. Filen kan derved etterpå 
leses og skrives sekvensielt fra den aksesserte 
sektorposisjonen. Imidlertid vil den siste sektoren 
som ble lest randomisert, bli lest om igjen når 
programmet går over til å lese sekvensielt. En annen 
måte å lese sekvensielt på, er å bare øke sekto- 
posisjonen gitt ved "r0","rl" og "r2" med 1 etter. 
hver leseoperasjon. 
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Funksjon 33 returnerer verdien 0 i AL-registeret hvis 
en sektor ble lest korrekt til filsystemets 
lese/skrive buffer i hukommelsen. Følgende verdier 
forskjelliq fra 0 returneres i AL-registeret ved feil: 


1,4 
6 


Sektor ikke tidligere skrevet 
Angitt sektor for stor 


Returkode 1 og 4 betyr at programmet har forsøkt å 
lese en uskrevet sektor. Feilkode 6 angir at logisk 
sektornummer er større enn maksimalt antall sektorer 
på platelageret (262144 = 32 Mb), dvs. "r2" i FKBen 
ved innhopp er større enn 3. 
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kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Funksjon 34: Skriv vilkårlig sektor å 
* ' * 
*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 
* * 
Æ Skriv vilkårlig sektor til fil * 
* * 
*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKK 
* é * 
* Inngangsparametre: * 
* * 
* Register CL: 22H * 
* Register DX: FKB offset adresse * 
- Register DS: FKB offset adresse * 
* * 
* Utgangsverdier: ” 
* * 
Å Register AL = 0 hvis sektor skrevet OK * 
* <> 0 hvis feil * 
* * 
* 


*kkkkkkkkkkkkkkkkkekkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 


Skriv-vilkårlig sektor funksjonen virker på samme måte 
som skriv sekvensielt funksjonen (21) bortsett fra at 
data skrives til en spesifisert vilkårlig sektor på 
filen. Posisjonen angis som et 18-bits tall i "ro", 
"rl" og "r2" feltene i FKBen, der "r0" representerer 
den laveste delen av sektortallet. "r2" feltet av 
FKBen må ha verdi mindre enn 4. Funksjonen reserverer 
også ny plass på platelageret hvis spesifisert sektor 
ikke før har vært skrevet. 


Feltene "r0"-"rl"-"r2" kan inneholde et sektorposisjon 
tall fra 0 til 262143. Enhver sektor på en maksimalt 
stor fil på over 33 millioner (33554432 = 32Mb) tegn 
kan derved skrives. Funksjonen øker ikke sektor 
telleren "ls" i FKBen med 1 slik skriv-sekvensielt 
funksjonen gjør. Påfølgende kall på funksjon 34 vil 
derfor skrive samme sektoren. 


Funksjonen beregner og setter alle FKB tellerne ("sm", 
"st" og "ls") ved hvert kall. Filen kan derved etterpå 
leses og skrives sekvensielt fra den aksesserte 
sektorposisjonen. Imidlertid vil den siste sektoren 
som ble skrevet ved funksjon 34, bli skrevet om igjen 
når programmet går over til å skrive sekvensielt. En 
annen måte å skrive sekvensielt på, er å bare øke 
sektorposisjonen gitt ved feltene "r0"-"rl"-"r2" med 1 
etter hvert funksjon 34 kall. 
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Funksjon 34 returnerer verdien 0 i AL-registeret hvis 
en sektor ble korrekt skrevet fra  filsystemets 
lese/skrive buffer i hukommelsen. Følgende verdier 
forskjellig fra 0 returneres i AL-registeret ved feil: 


5 
6 


Filkatalogen er full 
Angitt sektor for stor 


Returkode 5 betyr at katalogen på platen ikke har 
plass til mer filinformasjon. Feilkode 6 angir at 
logisk sektornummer er større enn maksimalt antall 
sektorer på platelageret (262144 = 32Mb), dvs. "r2" i 
FKBen ved innhopp er større enn 3. 
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kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkrkk 


* * 
* Funksjon 35: Beregn fil størrelse %* 
* * 
kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkK 
* * 
* Beregn størrelsen på en fil i * 
* antall sektorer * 
* * 
kK*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 
* * 
* Inngangsparametre: å 
* * 
" Register CL: 23H Å 
- Register DX: FKB offset adresse * 
- Register DS: FKB segment adresse * 
* * 
* Utgangsverdier: så 
* * 
N "RQ"-"R1"-"R2" feltene i FKBen satt å 
* * 
kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkRRKK 


Beregn-fil-størrelse funksjonen returnerer antallet 
sektorer filen består av i "RO0","Rl" og "R2" feltene i 
FKBen. FKBen må inneholde et entydig filnavn som 
brukes til å søke i filkatalogen. Returnert fil 
størrelse er sektor adressen til sektoren som etter- 
følger den siste sektoren på filen. Hvis "R2" feltet 
er 04 ved uthopp, er filen på maksimal størrelse, dvs. 
262624 filsektorer (= 32 Mb). Hvis "R2" er mindre enn 
4, vil "RO"-"Rl"-"R2" feltene (18 bits) inneholde 
filstørrelsen. 

Data kan skjøtes på en eksisterende fil ved å kalle 
funksjon 35 for å sette "RO0"-"Rl"-"R2" feltene, for 
deretter å utføre en sekvens av skriv-vilkårlig-sektor 
kall (funksjon 34) fra den beregnede sektoradressen. 


Beregnet filstørrelse er en logisk størrelse som er 
lik den fysiske størrelsen på en fil som er skrevet 
sekvensielt. Hvis filen er laget ved hjelp av skriv- 
vilkårlig-sektor operasjoner med "datahull" i filen, 
vil beregnet filstørrelse være større en fysisk 
størrelse. Eksempelvis vil en fil der bare den 
maksimalt siste sektoren (nr. 262143) er skrevet få 
beregnet filstørrelse på 262144 sektorer, mens filen 
fysisk*' kun opptar en blokk på platelageret. 
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**kkktækkkkekKkkkRkKTKKKTKKTKKK KKK KKKKKKK KERK KKRKK KK KK KKK 


* * 
* Funksjon 36: Beregn vilkårlig sektor * 
* * 
*kkkkkkkkkkkkkKkKTRKKKKKKKkKKKKKKKTKKkKRKKEKRKKKRK KK KKK 
* * 
* Beregn sektor nummer til neste sektor % 
- som skal leses eller skrives å 


* * 
kkkkkkkkkkkKKRkkKKKKKKRKKRKKKKRKRKKKKKKKKKKKKKKKKKKKKK 
* ; * 


* Inngangsparametre: % 
* * 
- Register CL: 24H * 
* Register DX: FKB offset adresse P 
på Register DS: FKB segment adresse * 
* * 
* Utgangsverdier: - 
* ; * 
* "RQO"-"R1"-"R2" feltene i FKBen satt DE 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkKKkKKKKRKK 
Beregn-vilkårlig-sektor funksjonen beregner det 


logiske sektornummeret for neste sektor på en fil som 
har vært aksessert ved hjelp av sekvensielle 
operasjoner. Funksjonen kan brukes på to måter. 


For det første kan'det ofte være nyttig å først lese 
en fil sekvensielt for å undersøke forskjellig 
"nøkkel"-felt. Etter som hvert nøkkelfelt finnes, kan 
funksjon 36 kalles for å lagre unna sektorposisjonen 
for mnøkkelfeltet. De forskjellige mnøkkelposisjonene 
kan lagres i en tabell for siden å kunne brukes til å 
behandle nøkkel-feltene direkte på filen ved hjelp å 
vilkårlig-sektor filoperasjoner. 


En annen bruk av funksjon 36 er ved overgang fra 
sekvensielle  filoperasjoner tid vilkårlig-sektor 
operasjoner. En fil kan således leses og skrives 
sekvensielt opp til et bestemt punkt, for deretter å 
behandles randomisert fra det bestemte punktet. 
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kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkK 


* * 
* Funksjon 37: Logg ut plater * 
* * 
*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKk 
* * 
” Logg ut spesifiserte platelagre * 
* * 
*KkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkRKK 
* * 
* Inngangsparametre: så 
* * 
- Register CL: 25H ” 
* Register DX: Plate vektor - 
* * 
* Utgangsverdier: å 
* * 
” Register AL: 0 å 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkRK 


Logg-ut-plater funksjonen brukes til å logge ut 
bestemte  platelagre fra filsystemet. Ved innhopp 
inneholder DX-registeret et l16-bit vektor som 
spesifiserer hvilke plater som skal logges ut. Bit-0O 
av DX-registeret satt til 1 betyr at plate A skal 
logges ut, mens bit-l5 av DX tilsvarer plate P. 


AL-registeret blir satt til 0 ved uthopp. 


å 


TIKOS program beskrivelse. 


K*kækeKkkkkkkkkKTKKRKTKTKKKKKTKKKKKRKKK RK KKKRKIEKKKRKRKKKRKK 


* * 
* Funksjon 40: Skriv vilkårlig sektor med * 
* NULL-stilling * 
* * 
*KkkkkkkkkkkkkkkkkkkkkkKKKKKKKKRKKKKKKKRKKKKRKKKKKRKKK 
* * 
* Skriv vilkårlig sektor til fil, fyll * 
* nye datablokker med 0 før de skrives % 
* * 
KkkkkkkkkkkkkkkkkkkkkkKkkkkKKKkRKKKKKKKKRKKKKRKKKKERK 
* : * 
* Inngangsparametre: % 
* * 
* Register CL: 28H * 
Register DX: FKB offset adresse kg 
» Register DS: FKB segment adresse *% 
* * 
* Utgangsverdier: * 
* * 
* Register AL = 0 hvis sektor skrevet OK * 
* <> 0 hvis feil % 
* * 
KkkkkkkkkkkkkkkkkkkkkkkkekkkkkkkKKKKKKkKKKKKKRKKKKK 


Funksjon 40 virker på samme måte som skriv-vilkårlig- 
sektor funksjonen (nr. 34) bortsett fra at nye 
datablokker på platelageret som brukes av filen, 
fylles med nuller før data skrives. 
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*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Funksjon 45: Sett feil-modus * 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkekk 
* * 
* Sett filsystem feil modus. * 
* * 
*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkRKKK 
* * 
* Inngangsparametre: - 
* * 
å Register CL: 2DH % 
Register DL: OFFH eller OFEH ” 
* * 
* Utgangsverdier: Å 
* * 
* Ingen % 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkRK 


Funksjon 45 setter filsystemets feilmodus. Feil- 
modusen bestemmer hvordan TIKOS oppfører seg ved 
disk feil. I normal modus, vil TIKOS ved disk feil 
skrive ut en av følgende fire meldinger på skjermen: 


Feil på <p>: Les/skriv 
Feil på <p>: Gal plate 
Feil på <p>: Fil KUN lesbar 
Feil på <p>: KUN lesbar 


UNE 
— — — — 


<p> = plate, A,B,..P 


Brukeren kvitterer på feilmeldingen ved å trykke en 
tast, og det kjørende programmet blir stoppet. 


Hvis filsystemet er satt i såkalt RETUR modus, vil 
ingen melding komme opp på skjermen, men en feilstatus 
vil bli returnert til det kjørende programmet. Feil- 
Statusen består i at AL-registeret ved uthopp blir 
satt til verdien OFFH, og AH-registeret vil bli satt 
til en av følgende feilkoder: 


01 - Ved "les/skriv" feil 
04 - Ved "gal plate" feil 
03 - Ved "fil KUN lesbar" feil 
02 - Ved "KUN lesbar" feil 


Funksjon 45 setter filsystemets feilmodus fra verdien 
av DL-registeret ved innhopp. Hvis DL-registeret er 
satt til OFFH, blir "vanlig" feilmodus satt. Hvis DL 
er forskjellig fra OFFH (bruk OFEH), vil filsystemet 
bli satt i RETUR modus. 
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*kkkkkkkkkkKkRkT KKK KKK KKKRKTKTKKTKKKRTTKKTKRKKKeKKKKKKRTK 


* * 
* Funksjon 47: Start opp et annet program * 
* ; * 
*kkkkkkkkkkkkkkkKkkkKKKkkTKKKKKKKKKKK KK KR KKKKKK KK 
* * 
% Avslutt kjørende program og start opp - 
5 et nytt. å 
* * 
KkkkkkkkkkkkKKKkkkkKKRKKKRKKKRKKKKKKKKKkkRIKKKRRKKK 
* * 
* Inngangsparametre: å 
* * 
* Register CL: 2FH 
- Inn/ut buffer inneholder kommandolinje * 
* * 
* Utgangsverdier: - 
* * 
* Ingen * 
* * 
kkkkkkkkkkkkkkkkkkkKkkkkkkke KKK KKKKKKKKKKRKKKKKK 


Funksjon 47 avslutter det kjørende programmet og 
starter opp et nytt. Filsystemets inn/ut buffer 
må ved innhopp være fylt med ønsket kommandolinje. 
Kommandolinjen må være lagret som en sammenhengende 
tekst streng avsluttet med 0, som vist nedenfor. 


Inn/ut buffer: 0 er n+1 


TIKOS program beskrivelse. 


kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Funksjon 50: Utfør TIUM88 funksjon * 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 
* * 
å Utfør funksjon i Tiki Inn/Ut modul TIUM88 |* 
* * 
*Kk*ækkkkkkkkkkkkkkkkkkkkKkkKkkRkKKkkkkkkkkkkkkkkkkkkkK 
* ' * 
* Inngangsparametre: ” 
* * 
* Register CL: 32H 
* Register DX: TIUMKB offset adresse * 
ha Register DS: TIUMKB segment adresse % 
* * 
* Utgangsverdier: . 
* * 
” TIUM88 retur - 
* X * 
kKkkkkkkkkekkkkkkrkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkK 


Funksjon 50 gjør det mulig for programmer å utføre 
basis inn/ut funksjoner i TIUM88 modulen. Ved innhopp 
må register DX inneholde adressen til en kontroll- 
blokk i hukommelsen, TIUMKB, med følgende innhold: 


TIUMKB: ! FUNK ! > EG DX å 


FUNK = TIUM88 funksjon nr. 
02 = tastatur status 
03 = tastatur inn 
04 = skjerm ut 
etc. 
CX = TIUM88-funksjon CX-register 
DX = TIUM88-funksjon DX-register 


Funksjonen 50 brukes mest for skjerm inn/ut 
operasjoner. 
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kKkkkkkkkk ket TNT KKK RKKKKRKRKKKKKKKKKKKKKRK KK 


* * 
* Funksjon 51: Sett lese/skrive segment adresse * 
* å , * 
kkkkkkkkkkkkkkkkkkkkkkkkkkKkKKKKReKKKKKKKKKKKKKRKKKKK 
* * 
” Sett filsystemets lese/skrive-buffer segment * 
* adresse. ” 
* * 


KökkkkkkkkkkkkkkKKKKKKKKKRKKKKKKKKKKKKKKKKRKKKKKKKK KR 
* 
Inngangsparametre: 


Register CL: 33H 
Register DX: Lese/skrive segment adresse 


Utgangsverdier: 


* 
* 
* 
* 
* 
* 
* 
* 
* Ingen 
* 

* 


* 
* 
* 
* 
* 
* 
* 
* 
* 
* 


*kkkkkeakkkkkkkkkkkkkkkkkkkkkkkKKKkKkKKKKKKTKKKKKKK 


Funksjon 51 brukes til å sette filsystemets lese/ 
skrive-buffer segment-adresse. Lese/skrive-bufferet er 
det 128-tegns området i hukommelsen som brukes til 
mellomlagring av data som skal overføres til og fra 
filer på platelagrene. Bufferet vil inneholde en 
filsektor FORAN skriveoperasjoner og ETTER lesekall. 


Når  TIKOS laste opp et program, vil lese- og 
skrivebufferet alltid være ' i adresse 80H % 
programmets datagruppe. Funksjon 51 trenger således 
bare benyttes for programmer som skal foreta fil 
lese- og skrive-operasjoner utenfor programmets egen 
datagruppe. 


76 


TIKOS program beskrivelse. 


*Kk*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Funksjon 52: Returner lese/skrive adresse på 
* * 
kKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkK 
* * 
* Returner filsystemets inn/ut buffer * 
* adresse. . 
* * 
kkkkkkkkkkkkkkkkkkkKkkkkkkkkkkkKKkkkkkKKKkkkkKKKKKRKK 
* * 


Inngangsparametre: 


Register CL: 34H 


Register AX: Inn/ut buffer offset adresse 


* 
* 
* 
* 
* Utgangsverdier: 
* 
* 
od Register ES: Inn/ut buffer segment adresse 
* 
* 


* 
* 
* 
* 
* 
* 
* 
* 
* 
* 


*ækkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkKkkkkkkkkkkKKkRK 


Funksjon 52 brukes til å lese av TIKOS nåværende 
fil inn/ut buffer adresse. Funksjonen kan være nyttig 
for programmoduler som trenger å endre inn/ut buffer 
adressen, men som senere ønsker å sette buffer 
adressen tilbake den opprinnelige verdien. 
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**kkkkkkkkkkkkkkkkKeRKKkKKRKKKKRTKKKKKKKKKKKKKKKKKKKKKK 


* * 
*. Funksjon 53: Hent maksimal hukommelse * 
* ; * 
*kkkkkkkkkkkkkkkkkkkkKKKKKKKKKKKKkKKKkKKKKTKKKKKKKKK KKK 
* * 
R Undersøk hvor mye hukommelse som maksimalt % 
* er tilgjengelig, ikke tildel ("alloker") * 
* * 


KkakkkkkkkkkkkkkkkRkKkKkkRRKKKKTRKKKTKRKKKKKRKKKKKKKKKKKKKK 
* * 
Inngangsparametre: 


Register CL: 35H 
Register DX: HKB offset adresse 
Register DS: HKB segment adresse 


Register AL 0 hvis hukommelse finnes 


OFFH hvis hukommelse mangler 


* * 
* * 
* * 
* * 
* * 
* . * 
* Utgangsverdier: % 
* * 
* * 
* * 
* * 
* * 


*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkekkkkeKKKKKKKKKK KK 


Funksjon 53 undersøker hvor mye hukommelse som er 
ledig for programmet. DX-registeret inneholder ved 
innhopp adressen til en hukommelses kontroll blokk, 
HKB, med følgende format: 


0 1 2 3 4 
HKB: ! BASE ! LENGDE ?! EXT ! 
BASE hukommelses segment adresse 


LENGDE = størrelse i antall paragrafer 
l paragraf = 16 hukommelses celler 


EXT ikke brukt, må være tilstede 


Funksjon 53 returnerer den største sammenhengende 
hukommelses-blokken som er mindre enn angitt LENGDE 
i HKB'en. Funksjonen fyller inn BASE- og LENGDE feltet 
i HKB'en for funnet hukommelse. Funksjonen returnerer 
0 i AL-registeret hvis hukommelse finnes. Ellers 
returneres OFFH i AL. 


Funksjon 53 tildeler ikke hukommelse. Funksjonen bare 
returnerer hvor mye som er ledig. 
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kKk*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkK 


* * 
* Funksjon 54: Hent absolutt maksimal hukommelse * 
* * 
*K*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKK 
* * 


Undersøk hvor mye hukommelse som maksimalt 
er tilgjengelig fra en angitt base, ikke 
tildel ("alloker") 


*ktkkkkkkkkkkkkkkkkkkkkkkkkkkkKKkKKkkkkRkkkkkkkkkkkKK 


* * 
* * 
* * 
* * 
* * 
* * 
* Inngangsparametre: - 
* * 
* Register CL: 36H % 
* Register DX: HKB offset adresse * 
* Register DS: HKB segment adresse * 
* * 
* Utgangsverdier: å 
* * 
* * 
* * 
* * 
* * 


Register AL = 0 hvis hukommelse finnes 
= OFFH hvis hukommelse mangler 


kkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkkkkkkkkkkkkkkkkKkKKK 


Funksjon 54 undersøker hvor mye hukommelse fra en fast 
base som er ledig for programmet. DX-registeret 
inneholder ved innhopp adressen til en hukommelses 


kontroll blokk, HKB, med følgende format: 
0 1 2 å 4 
HKB: ! BASE * ! LENGDE ! EXT ! 
BASE = hukommelses segment adresse 
LENGDE = størrelse i antall paragrafer 


1 paragraf = 16 hukommelses celler 
ikke brukt, må være tilstede 


EXT 


Funksjon 54 returnerer den største sammenhengende 
hukommelses-blokken fra spesifisert BASE som er mindre 
enn LENGDE feltet i HKB'en. Funksjonen fyller inn 
LENGDE feltet i HKB'en for funnet hukommelse. 
Funksjonen returnerer 0 i AL-registeret hvis 
hukommelse finnes. Ellers returneres O0FFH i AL. 


Funksjon 54 tildeler ikke hukommelse. Funksjonen bare 
returnerer hvor mye som er ledig. 
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*kkkkkkkkkkkkkkkkkkkKekKkKKKKT KKK KKK KK KE KKKRIKKKKKK 
* * 
* Funksjon 552: Tildel hukommelse * 
* * 
*kkkkkkkkkkkkkkkkkkkkkKKKKKkKKKKKKKKKKKKKKKKKKRKKRKRKKK 
* * 
* Tildel ("alloker") hukommelse til programmer * 
* * 
KkkkkkkkkkkkkkKkkkkkkkkKkkKTKKKKKRKKKKeRKKTERKKKRKKKKKKRKKK 
* * 
Inngangsparametre: 


Register CL: 37H 


Register DX: HKB offset adresse 
Register DS: HKB segment adresse 


0 ' hvis hukommelse finnes 
OFFH hvis hukommelse mangler 


Register AL 


* * 
* * 
* * 
* * 
* * 
* * 
* Utgangsverdier: * 
* * 
* * 
* * 
* * 
* * 


KkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKkkKKKKKRKKKK 


DX-registeret inneholder ved innhopp til funksjon 55 
adressen til en hukommelses kontroll blokk, HKB, med 
følgende format: 


HKB: : BASE 1 LENGDE 1! EXT I 


BASE = hukommelses segment adresse 
LENGDE = størrelse i antall paragrafer 
l paragraf = 16 hukommelses celler 


EXT ikke brukt, må være tilstede 


Funksjon 55 tildeler ("allokerer") hukommelse med 
lengde lik LENGDE feltet i HKB'en. Funksjonen fyller 
inn BASE-feltet i HKB'en for funnet hukommelse. 
Funksjonen returnerer 0 d AL-registeret hvis 
hukommelse finnes. Ellers returneres OFFH i AL. 
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*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Funksjon 56: Tildel absolutt hukommelse * 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 
* x 
N Tildel ("alloker") hukommelse til programmet * 
* på fast adresse 

* * 


Kk*kkkkkekkkkkkkkkkKkKKKkKkkKKkRkkKkKKKKKkkkKkKKkKKKKKAKKK 
* 


Inngangsparametre: 


Register CL: 38H 
Register DX: HKB offset adresse 
Register DS: HKB segment adresse 


Utgangsverdier: 


0 hvis hukommelse finnes 


Register AL 
OFFR hvis hukommelse mangler 


* 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 
* * 


*Kkkk*krkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 


DX-registeret inneholder ved innhopp til funksjon 55 
adressen til en hukommelses kontroll blokk, HKB, med 
følgende format: 


HKB: I BASE ! LENGDE ! EXT ! 


BASE = hukommelses segment adresse 
LENGDE = størrelse i antall paragrafer 

l paragraf = 16 hukommelses celler 
ikke brukt, må være tilstede 


EXT 


Funksjon 56 tildeler ("allokerer") hukommelse på en 
fast adresse spesifisert i BASE feltet i HKB'en og med 
lengde lik LENGDE feltet. Funksjonen returnerer 0 i 
AL-registeret hvis hukommelse finnes. Ellers 
returneres OFFH i AL. 
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kkkkkkkkkkkkkKkTKKKKK KK KKK KKK RKKKKkKK KKK KKK KKRKKKKKK 


* * 


* Funksjon 57: Frigi hukommelse * 
* * 
KkkkkkkkkKkkkkkKkkKKkKKKKKKKKKKKTKKKKTKKKTKKKKKKRKK KK KK RKK 


* * 
* Frigi tildelt hukommelse » 
* * 
*KkkkkkkkkkkkkkkkkkkkkkkkkkkKkkkKKKKKKKkKKKKKKKKKKKKRKK 
* * 


Inngangsparametre: 


Register CL: 39H 
Register DX: HKB offset adresse 
Register DS: HKB segment adresse 


Register AL 0 hvis tildelt fra før 


OFFH ikke tidligere tildelt 


* * 
* * 
* * 
* * 
* * 
* * 
* Utgangsverdier: % 
* * 
* * 
* * 
* * 
* * 


kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKKKKKKKRKKKKRKK 


DX-registeret inneholder ved innhopp til funksjon 57 


adressen til en hukommelses kontroll blokk, HKB, med 
følgende format: 


0 1 2 3 4 
HKB: å BASE ! LENGDE ! EXT ! 
BASE hukommelses segment adresse 


LENGDE størrelse i antall paragrafer 
l paragraf = 16 hukommelses celler 
EXT = kontroll ord 


Funksjon 57 frigir tildelt hukommelse. Hvis  EXT- 
feltet i HKB'en er lik 0, frigis hukommelse med 
angitt BASE og LENGDE i HKB'en. Hvis EXT er lik 
OFFH, frigis all hukommelse som er tildelt programmet, 
untatt den hukommelsen som opptas av programmet selv. 
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kkkkkkkkkkkkkkkkkkkKkKkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 


* * 
* Funksjon 58: Frigi all hukommelse » 
* * 
*kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk 
* * 
* Frigi all tildelt hukommelse, intitier * 
* hukommelses-tabeller * 
* * 
*KkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKK 
* * 
* Inngangsparametre: » 
* * 
% Register CL: 3AH * 
* * 
* Utgangsverdier: å 
* * 
* Ingen * 
* * 
kKkkkkkkekkkkkKKkKKKKKkKKkkkkRKKkkkkKkkKkKkKKKKkRKKKKKKKKKKKK 


Funksjon 58 frigir all tildelt hukommelse, inklusive 
hukommelsen hvor det kallende programmet ligger. 
Funksjonen initierer samtidig alle interne 
hukommelses-tabeller i TIKOS. 
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kKkækkkkekkkkkkKTKeRKKRkKKKKKKKKKKKKkKKKKRTKKKRKKKK TR K 


* * 
* Funksjon 59: Program last * 
* * 
*kækkkkkkkkkkkkKkKKRKKKKKKKKRKKKKKRKKTKRKKKKKKKRKKRKKKKK 
* * 
* Last et nytt program inn i hukommelsen * 
* * 
kKkkkkkkkkkkkkkkkkkkkkkKkKKKK KKK KKKKKKKRKKKKKKKKKKKK 
* * 
* Inngangsparametre: å 
* * 
* Register CL: 3BH N 
å Register DX: FKB offset adresse * 
* Register DS: FKB segment adresse ee 
* * 
* Utgangsverdier: * 
* * 
% Register AX: OFFFFH hvis feil v 
å Program systemområde segment * 
% adresse hvis OK lastet % 
* * 
kkkkkkkkkkkkkkkkkkkkkkkkkKkKkkKRKKkkkKKeRKKRKKRKKRKKK 


Funksjon 59 laster en CMD-type fil inn i hukommelsen 
og forbereder programmet for kjøring. Hukommelse blir 
tildelt det nye programmet, og program systemområdet 
blir satt opp. Programfilen gitt i FKB'en må være 
åpnet før funksjon 59 kalles. 


Ved uthopp blir register AX satt til OFFFFH ved feil. 
Ellers vil AX inneholde segmentadressen til det nye 
programmets systemområde. Adressene til de andre 
programgruppene fra CMD filen finnes i systemområdet. 
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2.10 TIKOS spesial funksjoner. 


TIKOS inneholder seks spesialfunksjoner for direkte 
kommunikasjon med hovedprosessoren 7280. Funksjonene 
gjør det mulig å utføre inn/ut operasjoner direkte 
mot 7Z80 porter, samt å lese/skrive direkte inn i 
Z80's hukommelse. Funksjonene utføres ved å sette 
opp passende verdier i 8088's registre, og dernest 
utføre en programstyrt "interrupt" (INT) maskinkode- 
instruksjon. 


2.10.1 Les Z80 dataport. 


8088 instruksjon: INT OAOH (160) 
Inngangsparameter: DX = 8 bit Z80 portadresse 
Utgangsparameter: AL = port verdi 


Denne funksjonen gjør det mulig å lese en Z80 dataport 
direkte. Z80's portnummer spesifiseres å DX- 
registeret, og lest portverdi blir returnert i AL. 


2.10.2 Skriv Z80 dataport. 


8088 instruksjon: INT OALH (161) 
Inngangsparametre: DX = 8 bit Z80 portadresse 

AL = port verdi 
Utgangsparametre: Ingen 


Denne funksjonen gjør det mulig å skrive til en Z80 
dataport direkte. Z80's portnummer spesifiseres i DX- 
registeret, og verdien som skal ut på porten settes 
i AL. 
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2.10.3 


2.10.4 


2.10.5 


Utfør Z80 subrutine. 
8088 instruksjon: INT OA2H (162) 


Inngangsparametre: AL Z80 A-register 


CX = 280 BC-register 
DX = 280 DE-register 
BX = 280 HL-register 
SI = 280 subrutine adresse 
Utgangsparametre: AL = 280 A-register 
CX = 280 BC-register 
DX = 0280 DE-register 
BX = 0280 HL-register 


Denne funksjonen gjør det mulig å utføre en 780 
subrutine på fast adresse. SI-registeret inneholder 
280 adressen ved innhopp, og subrutinens register- 
parametre overføres i tilsvarende 8088 registre som 
vist ovenfor. Z80-rutinens returparametre blir ved 
uthopp kopiert inn i de tilsvarende 8088 registre. 


Hent Z80 segment. 


8088 instruksjon: INT OA3H (163) 

Inngangsparametre: Ingen ' 

Utgangsparameter: AX = 280 segment base 
(OCO00H) 


280's 64K lokale hukommelse kan leses/skrives fra 
8088 prosessoren. "Interrupt"-funksjon 163 returnerer 
segment basen sett fra 8088 til 7280 hukommelsen. 
Når dette skrives er 0280 segmentbasen lik O0CO000H, 
men dette kan endres i senere versjoner. 


Flytt 8 bit hukommelse. 


8088 instruksjon: INT O0A4H (164) 
Inngangsparametre: DS FRA hukommelse segment 


SI = FRA hukommelse offset 

ES = TIL hukommelse segment 

DI = TIL hukommelse offset 

CX = Antall 8 bit celler 
Utgangsparametre: Ingen 


Denne funksjonen gjør det mulig å flytte en blokk 
8 bit hukommelse til/fra 280's lokale hukommelse 
fra/til 8088 hukommelsen. Flyttingen kan også kun 
foregå internt på Z80's lokale hukommelse. 
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2.10.6 Flytt 16 bit hukommelse. 


8088 instruksjon: INT OASH (165) 
Inngangsparametre: DS = FRA hukommelse segment 


SI = FRA hukommelse offset 

ES = TIL hukommelse segment 

DI = TIL hukommelse offset 

CX = Antall 16 bit celler 
Utgangsparametre: Ingen 


Denne funksjonen gjør det mulig å flytte en blokk 
16 bit hukommelse til/fra %780's lokale hukommelse 
fra/til 8088 hukommelsen. Flyttingen kan også kun 
foregå internt på Z80's lokale hukommelse. 
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Inn/Ut modul (TIUM88) 


Tiki Inn/Ut Modulen, TIUM88, irneholder 21 grunn- 
leggende funksjoner som brukes av det øvrige operativ- 
system (TIFS88). Innholdet i dette avsnittet er 
beregnet for spesielt interesserte, og behøver ikke 
leses for å kunne lage "vanlige" TIKOS programmer. 
TIUM88 funksjonene faller i 3 klasser, filsystem 
funksjonene, tegn inn/ut funksjoner, og en funksjon 
for spesifisering av tilgjengelig hukommelse. TIUM88 
modulen kopler TIKOS til Z80's elektronikknære 
programvare. TIUM88 modulen omf ormer de fleste 
innkommende funksjoner til kall på tilsvarende 
funksjoner i Z80's TIUM modul. 


TIUM88 modulen inneholder en hopptabell for de enkelte 
funksjonene i starten på modulen. Hopptabellen starter 
på fast adresse 2500 Hex fra starten av selve TIKOS 
operativsystemet. Hver funksjon bruker 3 hukommelses- 
celler i tabellen, 1 celle for hopp-instruksjonskoden 
("IMP") og 2 celler til den relative hoppadressen i 
TIUM88 modulen. Hopptabellens format er vist i tabell 
LG 


Brukerprogrammer kan i sjeldnere tilfeller kalle 
TIUM88 funksjoner direkte. Dette gjøres ved hjelp av 
TIKOS funksjon 50. 
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Adresse Nr. Innhold Beskrivelse 

TIUM88+0 0 JMP START : Kommer her etter at 
strømmen er slått på 

TIUM88+3 l JMP EXIT : Kommer her når et program 
«skal avslutte 

TIUM88+6 2 JMP TASTST Tastatur status, sjekker om 
stast er trykket 

TIUM88+9 3 JMP TASTINN ;Leser neste tegn fra tasta- 
:turet, venter til tast er 
;trykket. 

TIUM88+12 4 JMP SKJERMUT ;Skriver 1 tegn på skjermen 

TIUM88+15 5 JMP SKRIVUT ;Sender 1 tegn til skriver 

TIUM88+18 6 JMP PAPBÅNDI ;Skriv tegn på papirbånd, 
«leser fra serieport P2 

TIUM88+21 7  JMP PAPBÅNDU ;Les tegn fra papirbånd, 
;skriver til serieport P2 

TIUM88+24 8 JMP HJEM :Gå til spor 0 på platen 

TIUM88+27 9  JMP VELGPL :Velg ut en bestemt plate 

TIUM88+30 10 JMP SETTSP ;Velg et bestemt platespor 

TIUM88+33 11 JMP SETTSEK ;Velg en bestemt fysisk 
;ssektor på platen 

TIUM88+36 12 JMP SETTOADR ;Sett lese/skrive offset 
adresse 

TIUM88+39 13 JMP LES :Les fysisk sektor fra plate 

TIUM88+42 14  JMP SKRIV :Skriv fysisk sektor 

TIUM88+45 15 JMP SKRSTAT ;Se om skriver er klar til å 
smotta et nytt tegn 

TIUM88+48 16 JMP SEKTRANS ;Transformer logisk sektor 
stil fysisk sektor nummer 

TIUM88+51 17 JMP SETTSADR ;Sett lese/skrive segment 
«adresse 

TIUM88+54 18 JMP SEGTAB :Returner adresse til 
: hukommelses-tabell 

TIUM88+57 19 JMP HIUC Hent inn/ut celle 

TIUM88+60 20  JMP SIUC Sett inn/ut celle 

Tabell 2-5. TIUM88 hopptabell. 
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2.9.1 —TIUM8S funksjonene 


Nedenfor følger en kort beskrivelse av de enkelte TIUM88 


funksjonene. Funksjonene er identiske med standard 

CP/M-86 BIOS funksjoner. 

Funksjon 0: START - adresse TIUM88+0 
Funksjonen setter opp TIKOS systemet etter at 
strømmen er slått på. Funksjonen utfører en del 
grunnleggende oppsetting av elektronikken og 
eksekveres kun ved første gangs oppstart av 
TIKOS. 

Funksjon 1: EXIT - adresse TIUM88+3 
EXIT funksjonen utføres når et program har 
avsluttet ved hjelp av  'TIKOS funksjon 0. 
Funksjonen sørger for å reaktivere 280 


prosessoren. 


Funksjon 2: TASTS 
Utparameter: AL-reg 
AL-reg 


' TASTS sjekker om en 


adresse TIUM88+6 


OFFH hvis tegn klart 
0 hvis tegn ikke er klart 


tast er trykket på tastaturet. 


Funksjonen returnerer 0 i AL-registeret hvis ingen 


tast er trykket. 


Hvis 


nytt tegn er klart fra 


tastaturet returneres OFFH i AL. 


Funksjon 3: TASTINN 


Utparameter: AL-reg 
TASTINN returnerer 


AL-registeret. 
trykket. 
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Funkjonen venter 


adresse TIUM88+9 


Neste tegn 


i 
er 


tastaturet 
en tast 


fra 
til 


neste tegn 
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Funksjon 4: SKJERMUT - adresse TIUM88+12 
Innparameter: CL-reg = Skjerm tegn 
SKJERMUT funksjonen skriver tegnet i CL-registeret 
ut på videoskjermen. 

Funksjon 5: SKRIVUT - adresse TIUM88+15 
Innparameter: CL-reg = Skriver tegn 
SKRIVUT funksjonen sender tegnet i CL-registeret 
til tilkoplet skriver. Skriveren kan være 
tilkoplet TIKI datamaskinen enten via serie- eller 
parallell port. 

Funksjon 6: PAPBÅNDU - adresse TIUM88+18 
Innparameter: CL-reg = Tegn 
Reservert for å skrive et tegn til papirbånd. 


Brukes til å skrive til serieport P2. 


Funksjon 7: PAPBÅNDI - adresse TIUM88+21 
Utparameter: AL-reg = Lest tegn 


Reservert for å lese et tegn fra papirbånd. 


Brukes til å lese fra serieport P2. 


Funksjon 8: HJEM = adresse TIUM88+24 


HJEM funksjonen angir at lese/skrive hodet for 
disketter (eller andre platelagre) skal flyttes 
til spor 0. Den fysiske operasjonen vil som oftest 
ikke utføres før lesing eller skriving foretas. 
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Funksjon 9: VELGPL må adresse TIUM88+27 


Innparametre: CL-reg 
DL-reg 


Plate nummer 

0 hvis første aksess på 
platen etter system- 
opplast 


Utparameter: BX-reg 


adresse til platelager 
tabell for angitt plate 
BX-reg = 0 hvis platen ikke finnes 


VELGPL velger ut et bestemt TIKOS platelager, 0-15, 
for etterfølgende lese/skrive operasjoner. 
CL-registeret inneholder  platelager. Bvis DL- 
registeret er 0 ved innhopp, er dette første 
aksessen på platen etter at TIKOS er lastet opp 
eller etter en tidligere "frigivelse" av platen 
(funksjon 13 og 37). 


Funksjon 10: SETTSP - adresse TIUM88+30 


Innparameter: CX-reg = Spor nummer 


SETTSP funksjonen velger ut et bestemt spor, gitt 
i CX-registeret, på utvalgt platelager. 


Funksjon ll: SETTSEK åR adresse TIUM88+33 
Innparameter: CX-reg = Sektor nummer 


SETTSEK funksjonen velger ut en bestemt fysisk 
sektor, gitt i CX-registeret, på utvalgt plate og 


spor. 
Funksjon 12: SETTOADR - adresse TIUM88+36 
Innparameter: CX-reg = Lese/skrive offset adresse 


SETTOADR funksjonen setter systemets 1lese- 0g 
skrive offset adresse for filfunksjoner. All data 
som leses fra platelageret vil bli lagt ut i 
hukommelsen gitt ved denne adressen. Tilsvarende 
vil data som skrives til platelagrene tas fra 
denne hukommelsesadressen. TIUM88 overfører alltid 
blokker på 128 tegn til og fra platelagrene. 
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Funksjon 13: LES 4 adresse TIUM88+39 


0 hvis sektor lest OK 
-1 hvis lesefeil 


Utparameter: AL-reg 
AL-reg 


LES funksjonen leser en TIKOS sektor (=128 tegn) 
fra angitt plate/spor/sektor til hukommelsen gitt 
av spesifisert lese/skrive adresse. Funksjonen 
returnerer 0 i AL-registeret hvis lesingen gikk 
bra. Hvis lesefeil returneres O0FFH. 


Funksjon 14: SKRIV - adresse TIUM88+42 


Innparameter: CL-reg 0 hvis vanlig skriv 


CL-reg l hvis skriving til fil- 
katalogen 

CL-reg = 2 hvis skriving til 
'første sektor på en ny 
datablokk som ikke 
inneholder gyldig data 

Utparameter: AL-reg = 0 hvis sektor skrevet OK 
AL-reg = =-1 hvis skrivefeil 


SKRIV funksjonen skriver en TIKOS sektor (=128 
tegn) fra hukommelsen gitt ved spesifisert 
lese/skrive adresse ut på angitt adresse ut 
platelager/spor/sektor. Funksjonen returnerer 0 i 
AL-registeret hvis skrivingen gikk bra. Ved 
skrivefeil returneres O0FFH i AL. Ved innhopp 
inneholder CL-registeret verdiene 0,1 eller 2. 0 
betyr vanlig skriv, 1 betyr skriving til 
filkatalogen, mens 2 betyr skriv til første sektor 
på en datablokk som ikke er i bruk. Denne 
informasjonen brukes i TIUM88 til å effektivisere 
skriving CELL platelagre der fysisk sektor 
Størrelse er større enn 128 (for dobbel tetthet 
disketter er fysisk sektor 512 tegn). En effektiv 
metode for å minimalisere fysiske skrive- 
operasjoner ved store fysiske sektorstørrelser 
(såkalt "deblocking"), er av stor betydning for 
filsystemets hurtighet. 
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Funksjon 15:  SKRSTAT - adresse TIUM88+45 


Utparameter: AL-reg -l1 hvis skriver klar til 


å motta et nytt tegn 
0 hvis skriver IKKE er 
klar til å motta tegn 


AL-reg 


SKRSTAT funksjonen tester om tilkoplet skriver er 
klar til å motta et nytt tegn. Hvis skriveren er 
klar, returneres O0FFH i AL-registeret. Ellers 


returneres 0 i AL. 
Funksjon 16: SEKTRANS - adresse TIUM88+48 


Innparametre: CX-reg 
DX-reg 


Logisk sektor 

Adresse til 
transformasjons-tabell 
Fysisk sektor 


Utparameter: BX-reg 


SEKTRANS funksjonen omformer fra logisk sektor 
nummer til fysisk sektor ved hjelp av en 
konverteringstabell. CX inneholder logisk sektor 
nummer ved innhopp. Dette tallet brukes som en 
indeks i en konverteringstabell gitt ved DX- 
registeret. Indeksert tabellelement returneres i 
BX-registeret, som da er korrekt fysisk sektor. 


Funksjon 17: SETTSADR - adresse TIUM88+36 
Innparameter: CX-reg = Lese/skrive segment adresse 


SETTSADR funksjonen setter systemets lese- og 
skrive segment adresse for filfunksjoner. All data 
som leses fra platelageret vil bli lagt ut i 
hukommelsen gitt ved denne adressen. Tilsvarende 
vil data som skrives til platelagrene tas fra 
denne hukommelsesadressen. TIUM88 overfører alltid 
blokker på 128 tegn til og fra platelagrene. 
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Funksjon 18:  SEGTAB - adresse TIUM88+45 


Utparameter: BX-reg = adresse til segment 
tabell over hukommelse 


SEGTAB returnerer adressen til segment-tabellen 
som beskriver tilgjengelig hukommelse. Segment- 
tabellen er lagret i TIUM88 modulet, og har 
følgende format: 


gg Antall segm. ! 

| -—= — — — å —v å å å — — — — — — — ) 

Lo Segment 1 ! 

2 4 base ! 

| = = — — == — —— — =— —— — =— —— —— — -— ! 

3. 4 Segment 1 ! 

4! lengde ! 

ER Segment 2 ! 

6 ! base ! 

| =«=-=e—==—=—=——==—=—====— ] 

7 I Segment 2 ! 

8 ! lengde ! 

! etc. ! 
Funksjon 19: HIUC - adresse TIUM88+45 
Utparameter: AL-reg = inn/ut celle 


HIUC funksjonen henter fram aktuell verdi av 
systemets INN/UT celle som er lagret i Z80's 
hukommelse. Cellen blir brukt til å kunne dirigere 
terminal INN/UT enten til innebygget tastatur og 
tilkoplet videoskjerm eller til spesial-tilkoplet 
terminal over serielinje. INN/UT cellen er 
beskrevet under forklaringen til TIKOS funksjon 
7 E SVSHikt 2.9, 


Funksjon 19: SIUC - adresse TIUM88+45 
Innparameter: AL-reg = inn/ut celle 


SIUC funksjonen setter ny verdi inn i systemets 
INN/UT celle som er lagret i %Z80's hukommelse. 
Cellen blir brukt til å kunne dirigere terminal 
INN/UT enten til innebygget tastatur og tilkoplet 
videoskjerm eller til spesial-tilkoplet terminal 
over serielinje. INN/UT cellen er beskrevet under 
forklaringen til TIKOS funksjon 7 i avsnitt 2.9. 
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TIKOS program beskrivelse. 


2:92 


Filsystem tabellene. 


Hvert platelager i TIKOS er beskrevet i en platetabell 
for vedkommende plate. Platetabellene (PT) finnes i 
TIUM88 modulen som returnerer adressen til tabellen ved 
VELGPL funksjonen (funksjon nr. 9).  Platetabellene 


opptar hver 16 hukommelses-celler og har følgende 
format: 


(Lokasjon nr.) 


Platetabell inneholder følgende elementer: 


STR Adressen *: til sektor-transformasjons- 
tabellen for denne platen. Tabellen 
omformer fra logisk til fysisk sektor 
nummer og brukes av SEKTRANS funksjonen 
(nr. 17) å TIUM88-modulen. Hvis STR har 
verdien 0, vil ingen omforming fra logisk 
til fysisk sektor finne sted. Fysisk sektor 
vil da være lik logisk sektor. Platelagre 
som har samme sektoromforming kan dele de 
samme transformasjons-tabellene. 


0 Brukes til kladdeområder av filsystemet. 
KBUF Adresse til et 128-tegns kladdeområde som 
: brukes ved lesing og skriving av fil- 
. katalogen. Alle platetabellene kan 


adressere.:det samme KBUF området. 


 PPAR Adresse pa Å plateparameter-tabell, 


beskrevet nedenfor. Plater med samme plate- 
parametre kan dele parameter tabeller. 


SV Adresse til en sjekk vektor som brukes av 
filsystemet til å finne ut om disketter har 
vært byttet. Det må finnes en sjekk vektor 
pr. plate. Lengden av SV er gitt i plate- 
parameter-tabellen (PPAR). 


BLT Adresse til en blokk-allokerings tabell 
brukt til å holde oversikt over hvilke 
blokker på platene som er opptatt og 
ledige. Hvert platelager må ha sin egen 
allokeringstabell. Lengden av BLT er gitt 
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TIKOS programbeskrivelse. 


i plate-parameter-tabellen (PPAR). Adressen 
av BLT returneres av TIKOS programfunksjon 


27: 
Plate-parameter-tabellene (PPAR) opptar 15 
hukommelses-celler og har følgende format: 


(2) (1) Ly 7 42) 42) 031 (1 (2) (2) 


Hvert tabell-element er på enten 1 eller 2 
hukommelses-celler som angitt ovenfor.  Parameter- 
tabellen inneholder følgende elementer: 


SPS Antall Sektorer Pr. Spor på platen. 


BSF Blokk Skift Faktor. 2 opphøyd i BSF angir 
hvor mange TIKOS sektorer (128 tegn) som går 
i hver blokk på platelageret. BSF bestemmer 
derved blokkstørrelsen på platen. En blokk 
er den minste plassenheten som kan tildeles 
filer på platelageret. 


BM Blokk Maske. BM+1l angir hvor mange TIKOS 
sektorer som går i hver blokk. 


SM Segment Maske. Bestemt av antall blokker på 
platen (MD) og blokkstørrelsen (BLS) på 
følgende måte: ' 


l. Hvis maksimalt antall blokker på platen 
(MD) er mindre enn 256, er SM bestemt av 
følgende tabell: 


BLS SM 
1024 0 
2048 Å 
4096 3 
8192 7 

16384 15 


2. Hvis MD er større enn 255, bestemmes SM 
av følgende tabell: 


BLS SM 

1024 Ikke lovlig 
2048 0 

4096 å 

8192 3 
16384 7 
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TIKOS programbeskrivelse. 


MD 


MF 


AO og A1 


SVS 


KS 


Maksimal antall Datablokker på platen - 1. 
MD bestemmer også lengden av allokerings- 
vektoren BLT i platetabellen. Lengden er 
gitt ved (MD/8)+1. 


Maksimalt antall filelementer i Eil- 
katalogen på platen - 1. Bestemmer også 
verdien av AO og Al feltene (se nedenfor). 


Bit tabell over hvor mange blokker som er 
opptatt av filkatalogen. Bit 7 av AO 
tilsvarer blokk 0 på platen, bit 0 av AO 
tilsvarer blokk ÆR På samme måten 
representerer Al blokk 8-15 på platen. En 
l-er i en bit-posisjon angir at blokken er 
opptatt av filkatalogen. Hvert filelement i 
katalogen opptar 32 tegn. Hvis f.eks. 
platens blokkstørrelse er på 1024 tegn, vil 
således en blokk kunne inneholde 32 fil- 
elementer. Hvis platen skal ha plass til 64 
filer (MF=63) og blokkstørrelsen er 1024, 
vil 2 blokker måtte reserveres for fil- 
katalogen. Verdien av AO0 vil derved være 
OCO Hex, mens Al vil ha verdi 0. Dette er 
TIKOS'Ss standardverdier for enkel og dobbel 
tetthet disketter. 


Sjekk Vektor Størrelse. SVS bestemmes på 
følgende måte: 


l. Hvis platelageret er utskiftbart (f.eks. 
disketter), settes SVS til (MF+1)/4. 


2. Hvis platelageret er fast, settes SVS 
til Q. 


Katalog Start. Angir hvilket spor på platen 
filkatalogen starter. Normalt vil de 
ytterste sporene (fra spor 0) av plate- 
lagrene brukes til å lagre TIKOS systemet 
selv. For disketter vil TIKOS normalt oppta 
2 eller 3 spor. KS vil da være 2 eller 3. 
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8088? 


Vedlegg A. Feilmeldinger. 


VEDLEGG A 


Feilmeldinger. 


Feilmeldinger under program-opplast: 


Finner ikke TIKOS.SYS filen 
8088 prosessor mangler 
Hukommelse mangler 


Feil på 
Feil på 
Feil på 
Feil på 


<p>: 
<p>: 
<p>: 
<p>: 


Feilmeldinger under kjøring: 


Les/skriv 

Gal plate 

Fil KUN lesbar 

KUN lesbar <p> = A,B,.-P 


** <feilmelding> i: ssss:0000 - Programmet stoppet ** 


«<feilmelding> = Divisjon med 0 
«feilmelding> = Register overflyt 
«feilmelding» = IBM-PC interrupt 10 ulovlig 
«feilmelding> = Ulovlig interrupt <nn> 


<nn>=hex 
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Vedlegg B. Programfunksjons-sammendrag. 


Nr. 


NUURUNHO 


VEDLEGG 


B 


Programfunksjons-sammendrag. 


Funksjonsnavn 


Last opp TIKO 
Tastatur inn 
Skjerm ut 

Port inn 

Port ut 

Skriver ut 
Direktr terminal 
inn/ut 

Hent INN/UT celle 
Sett INN/UT celle 
Skriv tegnsekvens 


Les tastatur linje 
Tastatur status 
Versjonsnummer 

Initier filsystemet 
Velgut plate 

Åpne fil 

Lukk fil 

Søk etter første 

Søk etter neste 

Fjern fil >. 

Les sekvensielt 

Skriv sekvensielt 

Lag fil 

Endre filnavn 

Hent innloggingstabell 
Hent utvalgt plate 

Sett lese/skrive adresse 
Hent blokktabell adresse 
Skrivebeskytt plate 

Hent skrivebeskyttete 
plater 

Sett filattributt 

Hent platetabell adresse 
Sett/hent bruker nr. 

Les vilkårlig sektor 
Skriv vilkårlig sektor 
Beregn filstørrelse 
Beregn vi DE=FKB adresse 
Logg ut plater 

Skriv vilkårlig sektor 
med NULL-stilling 


Inn parametre 


Ingen 
Ingen 
E=tegn 
Ingen 
E=tegn 
E=tegn 
Se definisjon 


Ingen 

E=INN/UT celle 

DX=tegnsekvens- 
adresse 

DX=linjebuffer 

Ingen 

Ingen 

Ingen 

DL=plate nr. 

DX=FKB adresse 

DX=FKB adresse 

DX=FKB adresse 

Ingen 

DX=FKB adresse 

DX=FKB adresse 

DX=FKB adresse 

DX=FKB adresse 

DX=FKB adresse 

Ingen 

Ingen 

DX=adresse 

Ingen 

Ingen 

Ingen 


DX=FKB adresse 
Ingen 

Se definisjon 
DX=FKB adresse 
DX=FKB adresse 
DX=FKB adresse 
RO,R1,R2 
DE=Plate vektor 
DE=FKB adresse 
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Ut parametre 


Ingen 

A=tegn 

Ingen 

A=tegn 

Ingen 

Ingen 

Se definisjon 


A=INN/UT celle 
Ingeen 
Ingen 


Se definisjon 
AL=0/0FFH 
AX=0022H 
AL=0/0FFH 
Ingen 
AL=Katalog kode 
AL=Katalog kode 
AL=Katalog kode 
AL=Katalog kode 
AL=Katalog kode 
AL=Feilkode 
AL=Feilkode 
AL=Katalog kode 
AL=Katalog kode 
AX=Tabell 
AL=Plate nr. 
Ingen 
BX=adresse 
Ingen 
AX=vektor 


AL=Katalog kode 
BX=Adresse 

Se definisjon 
AL=Feilkode 
AL=Feilkode 
RO,R1l,R2 


Ingen 
A=feilkode 


VEDLEGG 


Vedlegg B. Programfunksjons-sammendrag. 


Programfunksjons-sammendrag, forts. 


Funksjonsnavn 


Sett filsystem feilmodus 


Start opp annet program 


Utfør TIUM88 funksjon 


Set inn/ut buffer segment 


Returner inn/ut adresse 


Hent maks. hukommelse 
tilgjengelig 

Hent maks. hukommelse 
tilgjengelig fra base 
Tildel hukommelse 
Tildel hukommelse fra 
fast base 

Frigi hukommelse 
Frigi all hukommelse 
Programlast 
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Inn parametre 


DL=feilmodus 
Se definisjon 
DX=TIUMKB 
DX=segment 
Ingen 

DX=HKB 


DX=HKB 


DX=HKB 
DX=HKB 


DX=HKB 
Ingen 
DX=FKB 


Ut parametre 


Ingen 

Ingen 

TIUM retur 
Ingen 

ES :BX=adresse 
AL=0/0FFH 


AL=0/0FFH 


AL=0/0FFH 
AL=0/0FFH 


AL=0/0FFH 
Ingen 
AL=0FFFFH/ 
systemområde 
til program 


Vedlegg C. Eksempel på TIKOS program 


VEDLEGG C 


Eksempel på TIKOS program. 


CP/M ASM86 1.1 SOURCE: INIV.A86 PAGE 1 


VER 1.25 TAB+59,8 SUB A86 INIV 


"ea =o 


;å** Display all interrupt vectors on TIKI-100 8088 card *** 


*kkkkkkkkkkkkkkkkkkkKkeRKKKKeRKRKRRTKKKKRRK RK 


* Programmer: Ingar Rune Steinsland 
% Orkim Data 


* Kordahlveien 13 

* 1521 Sperrebotn 

* Norway 

* 

%* Date: January 23, 1985 
* 

* 


| EE AE 2 JE AE AE 


Last update: January 23, 1985 


* * 


* (The program is NOT too well documented) * 
KkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkKR 


we oe 0 ma mo mo mo mo ma mo NO me NO me ma 


pagesize 50 
pagewidth 90 


kkkkkkkkækkkkkkkkk 


* ASCII symbols: * 
kkkkkkkkkkkkkkkkkk 


=o "eo "oe "eo 


eo 


000D cr equ Odh 
000A LE equ O0ah 
0020 Space equ 20h 
; *kkkkkkkkkkkkkkkkkkkkkdkkkdkk 
; * Other userful constants: * 
: kkkkkkkkkkkkkkkkkkkkktktkkkk 
0000 b equ byte ptr 0 
0000 W equ word ptr 0 
0000 false equ 0 
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Vedlegg C. Eksempel på TIKOS program 


CP/M ASM86 1.1 SOURCE: INTV.A86 PAGE 2 


FFFF true equ not false 


kkkkkkkkkkkkkkkkkkkkkkk 


* Start of code area: * 
kkkkkkkkkkkkkkkkkkkkkkk 


*-e "eo "å "eo "me 


CSEG ; Small model 
ORG 0 

0000 E96201 0165 jmp start 
0003 CDEO tikos: int 224 ; Execute TIKOS function 
0005 C3 ret 
0006 50 conout: push ax + Output AL to screen 
0007 06 push es 
0008 56 push si 
0009 BlLO2 mov cl,2 
000B 8AD0 mov dl,al 
poke re 0003 call tikos 

E si 
0011 07 E es 
0012 58 pop ax 
0013 c3 ret 

outtext: : Output text constant 
0014 AC lods al 
0015 OACO or al,al 
0017 7405 OOLE jz outex 
0019 ESEAFF 0006 call —conout 
001C EBF6 0014 jmps outtext 
O01E C3 outex: ret 
computehxdigit: + compute ASCII HEX digit from AL 

O01F 240F and al,0fh 
0021 0430 add 21,0" 
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Vedlegg C. Eksempel på TIKOS program 


CP/M ASM86 1.1 SOURCE: INIV.A86 


0023 
0025 
0027 
0029 


002A 
002B 
002C 
002E 
0030 
0032 
0035 
0037 
0039 
003C 
003D 
003E 


003F 
0040 
0041 
0044 
0045 
0047 
004A 
004B 
004E 
004F 
0050 


0051 
0052 
0054 


3C39 
7602 
0407 
3 


0029 


OOLF 


00LF 


002A 


0006 
0006 


003F 


PAGE 3 
cmp al, "9" 
jbe chdl 
add al,7 
chdl: ret 
' 
computehxbyte: ; compute ASCII HEX digits 
push CX : from AL. Result in AX 
push bx 
mov bl,al : save LSB 
mov cl,4 
shr al,cl 
call computehxdigit 
mov ah,al 
mov al,bl 
call computehxdigit 
pop bx 
pop CX 
ret 
displayhexbyte: ; display binary byte as 2 HEX 
push ax 
push bx 
call computehxbyte 
push ax 
mov al,ah 
call conout 
pop ax 
call conout 
pop bx 
pop ax 
ret 
displayhexword: ; display binary word (AX) as 4 
push ax 
mov al,ah 
call displayhexbyte 
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CP/M ASM86 1.1 SOURCE: INTV.A86 


0057 
0058 
005B 


005C 
005D 
005F 
0061 
0063 
0065 
0067 
0069 
006A 
006D 
006E 
006F 


0070 
0071 
0072 
0073 
0075 
0077 
0079 
007B 
007E 
0080 
0082 
0084 
0086 
0089 
008B 
008D 
0090 
0091 


003F 


005C 


outddig: 


pop 
call 


ret 


Vedlegg C. Eksempel på TIKOS program 


PAGE 


ax 
displayhexbyte 


: Output decimal digit 


: Output decimal number 


dl, '0' 
outddig 
dx 

bx 
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Vedlegg C. Eksempel på TIKOS program 


CP/M ASM86 1.1 SOURCE: INIV.A86 PAGE 5 
0092 58 pop ax 
0093 C3 ret 
test if default vector: ; Check if standard vector 
0094 2BCO sub ' ax,ax 
0096 8ECO mov e5,ax 
0098 8BF9 mov di,cx 
009A DLE7 shl di, 1 
009C D1E7 shl di,l 
009E 268B05 mov ax,es:ÆdiÅ 
00A1 3B0O6AA03 camp ax,default offset 
00A5 7508 O0AF jnz tidex 
00A7 268B4502 mov ax,es:2ÆdiÅ 
00AB 3B06AC03 cmp ax, default segment 
00AF C3 tidex: ret 
displaymodule: Display module where 


PPT 


vector points 


00BO 51 push CX 

00Bl BES8DO03 mov si,offset spactx 
00B4 E85DFF 0014 call outtext 

00B7 59 pop CX 

00B8 2BCO sub ax, ax 

00BA 8ECO mov e5,axX 

00BC 8BF1 mov si,cx 

00BE 03F6 add si,si 

00C0 03F6 add si,si 

00C2 268B4402 mov ax,es:2ÆsiÅ ; Get segment 
00C6 BEACO1 mov si, offset questx 
00C9 3B0O6AEO03 cmp ax,tikosseg 

OOCD 750D 00DC jnz dimo 

0OCF BEC201 mov si,offset tikostx 
00D2 803EBOO3FF CnPp realtikos,true 
00D7 7403 00DC jz dimo 

00D9 BECDO1 mov si,offset ccpmtx 
OODC 51 dimo: push CX 
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CP/M ASM86 1.1 SOURCE: INTV.A86 


00DD E834FF 
00£0 59 
00E1 C3 


00E2 51 
00E3 BE9803 
00E6 E82BFF 
00E9 59 
00EA BEO001 
00ED BAOEO0 
00FO 3A0C 
00F2 7505 
00F4 46 
00F5 8B34 
00F7 EBO9 
00F9 83C603 
00FC 4A 
O0FD 75F1 
OOFF BEB701 
0102 51 
0103 ESOEFF 
0106 59 
0107 C3 


0108 E889FF 
010B 743E 
010D 51 
010E BE7FOL 
0111 E800FF 
0114 58 
0115 50 
0116 E857FF 
0119 BE9701 
O11C ESFSFE 


0014 


call 


pop 
ret 


displaytype: 


0014 


ditl: 
00F9 


0102 
ditl: 
00FO 


ditx: 
0014 


push 
mov 


call 


pop 
mov 


jmps 
add 
dec 
jnz 
mov 
push 
call 


pop 
ret 


displayvector: 


0094 
014B 


0014 


0070 


0014 


call 
jz 
push 
mov 
call 
pop 
push 
call 
mov 
call 


outtext 
CX 


CcX 


Vedlegg C. Eksempel på TIKOS program 


PAGE 6 


; Display ASCII vector type 


si,offset typseptx 


outtext 


CX 
si,offset typetab 


dx, typetIG 
cl,ÆsiÅ 
ditl 

si 
si,ÆSiÅ 
ditx 

41,3 

dx 

ditl 


si, offset ques2tx 


CX 
outtext 
CxX 


: Display vector 


test if default vector 


dexit 
CX 


si,offset intno tx 


outtext 
ax 

ax 
decout 


si, offset value tx 


outtext 
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Vedlegg C. Eksempel på TIKOS program 


CP/M ASM86 1.1 SOURCE: INTV.A86 


PAGE 


OT. - 
ax,es:2ÆdiÅ 
es:wÆdiÅ 
displayhexword 
al,':' 

conout 

ax 
displayhexword 
CX 

CX 
displaymodule 
displaytype 
si,offset crlf tx 
outtext 

CX 


di., 150 
di, 

di,1l 

ax,ax 
es,ax 
ax,es:ÆdiA 
default offset,ax 
ax,es:2ÆdiÅ 
default segment,ax 


"oe "oe 


(So far, so good) 


O11F 2BCO sub 
0121 8ECO mov 
0123 5F pop 
0124 57 push 
0125 DLE7 shl 
0127 D1E7 shl 
0129 268B4502 mov 
012D 26FF35 push 
0130 ESLEFF 0051 call 
0133 BO3A mov 
0135 ES8CEFE 0006 call 
0138 58 pop 
0139 ESL5SFF 0051 call 
013C 59 pop 
013D 51 push 
OL3E E86FFF 00BO call 
0141 ES89EFF 00E2 call 
0144 BEA003 mov 
0147 ESCAFE 0014 call 
014A 59 pop 
014B C3 dexit: ret 
get default vector: 
014C BF9600 mov. 
014F D1E7 shl 
0151 DLE7 shl 
0153 2BCO sub 
0155 8ECO mov 
0157 268B05 mov 
015A A3AA03 mov 
015D 268B4502 mov 
0161 A3AC03 mov 
0164 C3 ret 


PE LI 


kKkkkkkkkkkkkkkkk 
* Main program: * 
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Never-used int function 


Vedlegg C. Eksempel på TIKOS program 


CP/M ASM86 1.1 SOURCE: INIV.A86 PAGE 8 

Få kkkkkkkkkkkkkkkkk 
0165 lE start: push ds s Local stack 
0166 17 pop SS 
0167 BC7904 mov sp, offset stack 
016A BE2FO1 mov si,offset signon 
016D ESA4FE 0014 call outtext 
0170 ESD9FF O14C call get default vector 
0173 C606BOO3FF mov realtikos,true 
0178 BLOC mov cl,12 : Get version no. 
017A E886FE 0003 call tikos 
017D 8C06AE03 mov tikosseg,es : Save segm. of TIKOS 
0181 3C22 cmp al,22h : Ver. 2.2 means TIKOS 
0183 740E 0193 jz tikosthere 
0185 C606B00300 mov —realtikos,false 
018A BL9A mov cl,9ah ; Must be CCPM 
018C E874FE 0003 call tikos 
018F 8C06AE03 mov —tikosseg,es 

tikosthere: 
0193 B90000 mov cx; 0 
0196 ES6FFF 0108 mloop: call displayvector 
0199 41 inc CX 
019A 81F90001 cmp cx, 256 
019E 72F6 0196 jb mloop 

: Done, exit program 

01A0 BLOO mov cl,0 
01A2 B200 mov dl,0 
01A4 E95CFE 0003 jmp tikos 

* kkkkkkkkkkkkkkkkk 

; * Data segment: * 

, kkkkkkkkkkkkkkkkk 

DSEG 
org 100h 
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Vedlegg C. Eksempel på TIKOS program 


CP/M ASM86 1.1 SOURCE: INTIV.A86 


' 
0100 typetab rb 
0100 00 db 
0101 D801 dw 
0103 01 db 
0104 EBOL dw 
0106 02 db 
0107 0702 dw 
0109 03 db 
OLOA 2A02 dw 
010C 04 db 
OLOD 4702 dw 
OLOF 10 db 
0110 6E03 dw 
0112 AO db 
0113 6002 dw 
0115 Al db 
0116 7A02 dw 
0118 A2 db 
0119 9602 dw 
O11B A3 db 
O11C B002 dw 
OLLE A4 db 
OL1F D402 dw 
0121 A5 db 
0122 FD02 dw 
0124 EO db 
0125 2703 dw 


Oo 
-= 
[6] 
SS 
rm 
- 
26 


å 
E 
å 


we "my "oe "eo 


PAGE 


7 
0 s functions 


(offset $ - offset typetab)/3 


Kkkkkkkkkkkkkkkkkk 


* User messages: * 
kkækkkkkkkkkkkkkk 
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Vedlegg C. Eksempel på TIKOS program 
CP/M ASM86 1.1 SOURCE: INIV.A86 PAGE 10 


012A 54494B4928 db "'TIKI(' ; Tiki text standard 
2F ODOA signon db cr,1f 

He 566973203830 E db 'Vis 8088 avbrudds-tabell for TIKI-100 " 
383820617662 
72756464732D 
746162656C6C 
20666F722054 
494B492D3130 
3020 

0157 313620626974 db '16 bit prosessor - ver 1.00',cr,1f,1f 
2070726F7365 
73736F72202D 
207665722031 
2E30300D0A0A 

0175 000000000000 db 0,0,0,0,0,0,0,0,0,0 
000 

O17F el intno tx db 'Avbrudd nr: ',0,0,0,0,0,0,0,0,0,0,0 
64206E723A20 Få 
200000000000 
000000000000 

0197 202020566572 value tx db ' Verdi: ',0,0,0,0,0,0,0,0,0,0,0 
64693A200000 
000000000000 
000000 

O1AC 3F2020202000 questx 
0000000000 

01B7 3F2020202000 ques2tx 
0000000000 

0102 54494B4F5300 tikostx 
0000000000 

O1CD 4343504D2000 ccpmtx 
0000000000 

01D8 44697669736A divZEROtx 
6F6E206D6564 
203000000000 


121," er v vo ',0,0,0,0,0,0 
ang EN ta ti ",0,0,0,0,0,0 
"TIKOS',0,0,0,0,0,0 


"CCPM ',0,0,0,0,0,0 


pH ER EE 8 


"Divisjon med 0',0,0,0,0,0 
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Vedlegg C. Eksempel på TIKOS program 


CP/M ASM86 1.1 SOURCE: INIV.A86 


O1EB 


0207 


022A 


0247 


0260 


027A 


0296 


00 
50726F736573 
736F7220656E 
6B656C742073 
746567000000 
00000000 
496B6B65206D 
61736B657262 
617274206176 
627275646420 
284E4D492900 
0000000000 
496E6E686F70 
702074696C20 
226465627567 
676572220000 
0000000000 
526567697374 
6572206F7665 
72666C797400 
000000000000 
00 
4C6573206672 
61205A383020 
64617461706F 
727400000000 
0000 
536B72697620 
74696C205A38 
302064617461 
706F72740000 
00000000 
5574667C7220 
5A3830207375 
62727574696E 
650000000000 


singstepTX 


breakptx 


ovfltx 


Z80intx 


z800uttx 


exectx 


db 
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PAGE 11 


"Prosessor enkelt steg',0,0,0,0,0,0,0 


"Ikke maskerbart avbrudd (NMI)',0,0,0,0,0,0 


"Innhopp til "debugger"',0,0,0,0,0,0,0 


"Register overflyt',0,0,0,0,0,0,0,0 


"Les fra Z80 dataport',0,0,0,0,0,0 


"Skriv til Z80 dataport',0,0,0,0,0,0 


"Utfør Z80 subrutine',0,0,0,0,0,0,0 


CP/M ASM86 1.1 SOURCE: INTV.A86 


02B0 


02D4 


02FD 


0327 


0347 


0000 
52657475726E 
6572205A3830 
207365676D65 
6E7420616472 
657373650000 
000000000000 
466C79747420 
382D62697420 
6F7264207469 
6C2F66726120 
5A3830206875 
6B2E00000000 
0000000000 
466C79747420 
31362D626974 
206F72642074 
696C2F667261 
205A38302068 
756B2E000000 
000000000000 
46756E6B736A 
6F6E732D696E 
6£686F707020 
616472657373 
650000000000 
0000 
46756E6B736A 
6F6E732D696E 
6E686F707020 
667261202264 


656275676765. 


722200000000 
000000 


036E 49424D2D5043 


207370657369 


z80segtx 


movbtx 
-0,0,0 


tikoenttx 


debenttx 
,0 


ibmtx 


Vedlegg C. Eksempel på TIKOS program 


PAGE 12 


db 'Returner Z80 segment adresse',0,0,0,0,0,0,0,0 


db 'Flytt 8-bit ord til/fra Z80 huk.',0,0,0,0,0,0 


db 'Flytt 16-bit ord til/fra Z80 huk.',0,0,0,0,0, 


db 'Funksjons-innhopp adresse',0,0,0,0,0,0,0 


db 'Funksjons-innhopp fra "debugger"',0,0,0,0,0,0 


db 'IBM-PC spesial funksjon',0,0,0,0,0,0,0,0 
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Vedlegg C. Eksempel på TIKOS program 


CP/M ASM86 1.1 SOURCE: INIV.A86 


616C2066756E 
6B736A6F6E00 
000000000000 
00 
038D 202000000000 spactx 
0000000000 
0398 202D20000000 typseptx 
0000 
03A0 0D0A000000 SPELE t3 
03A5 2954494B49 
? 
? 
; 
03AA default offset 
03AC default segment 
03AE tikosseg 
03B0 realtikos 
03BL stock 
0479 0000 stack 
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db , Va ",0,0,0,0,0,0,0,0,0 


db ' -— ",0,0,0,0,0 


db cr,1£,0,0,0 
db ')TIKI' 


kKkkkkkkkkkkkkkkkkRkNRR 


* Scratch variables: * 
kkækkkkkkkkkkkkkkkkAKKK 


default interrupt 
routines 

OPSYS segment 
True if tikos 


o2d22 
HEHE RDn 


Local stack - 


100 F 
; Produce HEX output 


23 


' 
gkkkkkkkkkkkkkkkkkk kokk End program kkækkkkkkkkkkRTRKT RTR TR 


end 


END OF ASSEMBLY. NUMBER OF ERRORS: 


0. USE FACTOR: 2% 
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Vedlegg D. ASCII tabell. 


VEDLEGG D 
ASCII tabell. 
Nedenfor følger en oversikt over alle 7-bits tegnkodene som 


brukes i TIKOS. Kodene er standard ASCII pluss koder for de 
norske bokstavene Æ,Ø og Å. 


Desimal Hexadesimal Tegn 
000 00 Null 
001 01 Kontroll A 
002 02 Kontroll B 
003 03 Kontroll C 
004 04 Kontroll D 
005 05 Kontroll E 
006 06 Kontroll F, ACK 
007 FG Kontroll G, BELL 
008 08 Kontroll H, "<-" 
009 09 Kontroll I, TAB 
010 OA Kontroll J, LF 
o11 0B Kontroll K 
012 OC Kontroll L, FF 
013 OD Kontroll M, CR 
014 OE Kontroll N 
015 OF Kontroll O 
016 10 Kontroll P 
017 11 Kontroll Q, XON 
018 12 Kontroll R 
019 13 Kontroll S, XOFF 
020 14 Kontroll T 
021 15 Kontroll U, NAK 
022 16 Kontroll V, SYN 
023 Å Kontroll W 
024 18 Kontroll X 
025 19 Kontroll Y 
026 lA Kontroll Z 
027 1B Kontroll Æ, ESC 
028 1C Kontroll Ø 
029 1D Kontroll Å 
030 lE Kontroll ” 
031 lF Kontroll 
032 20 (Space) 
033 > Å ! 
034 22 D 
035 23 i 
036 24 $ 
037 25 % 
038 26 & 
039 27 * 
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Vedlegg D. ASCII tabell. 


Desimal 


040 
041 
042 
043 
044 
045 
046 
047 
048 
049 
050 
051 
052 
053 
054 
055 
056 
057 
058 
059 
060 
061 
062 
063 
064 
065 
066 
067 
068 
069 
070 
071 
072 
073 
074 
075 
076 
077 
078 
079 
080 
081 
082 
083 
084 
085 
086 
087 
088 
089 
090 
091 
092 


Hexadesimal 


=e+ $+- mm å] 
D 
Q 
jon) 


VIA OOS AURKWUNKHONVE 


QMNKXXE<CHODOVOZAPAHUHIAMNHNUNWUP» 


Vedlegg D. ASCII tabell. 


Desimal Hexadesimal Tegn 
093 5D A 
094 5E så 
095 5F 
096 60 å 
097 61 a 
098 62 b 
099 63 C 
100 64 d 
101 65 e 
102 66 f 
103 67 g 
104 68 h 
105 69 L 
106 6A G 
107 6B k 
108 6C 1 
109 6D m 
110 6E n 
111 6F Oo 
112 70 |) 
113 71 q 
114 72 ka 
115 73 s 
I16 74 & 
117 75 u 
118 76 v 
119 77 wW 
120 78 x 
121 79 Y 
122 7A Å 
123 7B æ 
124 TG Ø 
125 7D å 
126 TE | 
127 7D DEL 


Vedlegg E. Literaturhenvisninger. 


VEDLEGG E 


Listen nedenfor refererer kjente bøker som kan være 
nyttige å ha lest når en skal arbeide med Tiki-100 


datamaskinen: 

Forfatter Tittel Forlag 
Rodnay Zaks CP/M Handbook with MP/M Cybex 
Rodnay Zaks Programming the Z80 Cybex 
Allan R. Miller Mastering CP/M Cybex 
Andy Johnson-Laird The Programmer's CP/M Osborne/ 


handbook McGraw-Hill 
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Vedlegg F. Anmerkninger. 


VEDLEGG F 


Anmerkninger. 


Denne siden er tenkt reservert for brukerens personlige ned- 
tegninger. Kommentarer forøvrig kan sendes Tiki-Data A.S. 
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Tiki-Data a/s 
Sinsenveien 53, 
0585 Oslo 5 


Sats: Jonny Bunæs Grafisk A/S 
Trykk: Ski Papirindustri A/S 
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